博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
InsertSort 插入排序算法
阅读量:4097 次
发布时间:2019-05-25

本文共 822 字,大约阅读时间需要 2 分钟。

InsertSort 插入排序算法:

平均比较和移动次数为(n^2)/4,时间复杂度也为O(n^2)

直接插入排序比冒泡和简单选择排序的性能要好一些。

思路:

从第二个数开始遍历到最后一个数,如果当前的数小于前一个数,用tmp保存当前数,比较前面的数与tmp的大小,

如果比tmp大则将前面的数往后移动一位,最终将tmp存放在没有再比tmp数大的那个数的位置。

代码:

//插入排序(排序后为从小到大)#include 
#include
using namespace std;void InsertSort(int (&a)[7]){//数组作为引用形参传入,使用在此修改对原数组也有效 int aSize = sizeof(a) / sizeof(a[0]);//取数组的大小 int tmp;//设置一个空变量,来保存当a[i]
tmp&&j >= 0; --j){//如果前面的数都小于当前数 a[j + 1] = a[j];//将前面的这些数位置后移一位 } a[j + 1] = tmp;//将这个a[i]放到没有比它大的数之前 } }}int main(){ int a[] = {12, 42, 6, 17, 32, 4, 19 }; cout << "Before Sorted:" << endl; for (size_t i = 0; i < 7; ++i){//输出 cout << a[i] << " "; } cout << endl; InsertSort(a); cout << "After Sorted:" << endl; for (size_t i = 0; i < 7; ++i){//输出 cout << a[i] << " "; } cout << endl; return 0;}
程序输出:

你可能感兴趣的文章
Java各种集合类的合并(数组、List、Set、Map)
查看>>
JS中各种数组遍历方式的性能对比
查看>>
Mysql复制表以及复制数据库
查看>>
进程管理(一)
查看>>
linux 内核—进程的地址空间(1)
查看>>
存储器管理(二)
查看>>
开局一张图,学一学项目管理神器Maven!
查看>>
Android中的Binder(二)
查看>>
Framework之View的工作原理(一)
查看>>
Web应用架构
查看>>
设计模式之策略模式
查看>>
深究Java中的RMI底层原理
查看>>
用idea创建一个maven web项目
查看>>
Kafka
查看>>
9.1 为我们的角色划分权限
查看>>
维吉尼亚之加解密及破解
查看>>
DES加解密
查看>>
TCP/IP协议三次握手与四次握手流程解析
查看>>
PHP 扩展开发 : 编写一个hello world !
查看>>
inet_ntoa、 inet_aton、inet_addr
查看>>