插入排序C++实现
发布时间:2020-12-16 07:46:01 所属栏目:百科 来源:网络整理
导读:今天PHP站长网 52php.cn把收集自互联网的代码分享给大家,仅供参考。 //⒈ 从第一个元素开始,该元素可以认为已经被排序//⒉ 取出下一个元素,在已经排序的元素序列中从后向前扫描//⒊ 如果该元素(已排序)大于新元素,
以下代码由PHP站长网 52php.cn收集自互联网 现在PHP站长网小编把它分享给大家,仅供参考 //⒈ 从第一个元素开始,该元素可以认为已经被排序 //⒉ 取出下一个元素,在已经排序的元素序列中从后向前扫描 //⒊ 如果该元素(已排序)大于新元素,将该元素移到下一位置 //⒋ 重复步骤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; } } 以上内容由PHP站长网【52php.cn】收集整理供大家参考研究 如果以上内容对您有帮助,欢迎收藏、点赞、推荐、分享。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |