| 注册
请输入搜索内容

热门搜索

Java Linux MySQL PHP JavaScript Hibernate jQuery Nginx
x286
10年前发布

插入排序C++实现

//⒈ 从第一个元素开始,该元素可以认为已经被排序  //⒉ 取出下一个元素,在已经排序的元素序列中从后向前扫描  //⒊ 如果该元素(已排序)大于新元素,将该元素移到下一位置  //⒋ 重复步骤3,直到找到已排序的元素小于或者等于新元素的位置  //⒌ 将新元素插入到下一位置中  //⒍ 重复步骤2~5  #include<iostream>  #include<array>  using namespace std;      template<class T>  void insertion_sort(T&, int);      int main()  {  array<int, 10> arr={1,3,2,5,4,6,8,7,9,0};  insertion_sort(arr, arr.size()); //输入数组和数组大小,因为array是类,所以我们没法拿arr当数组首地址用,我们直接引用array类  for(int i = 0; i < 10; i++)  {  cout << arr[i] << endl;  }      cin.get();  return 0;  }      template<class T>  void insertion_sort(T& arr, int count)  {  int p = 0;  for(int i = 1; i < count; i++)  {  auto number = arr[i];  for(p = i; p > 0 && number < arr[p-1]; p--)  {  arr[p] = arr[p-1];  }  arr[p] = number;  }  }