插入排序算法
2016-09-04 15:51
218 查看
假设我们输入的是 “5,1,4,2,3” 我们从第二个数字1开始,看1有没有正确的位置,将1和左边的数字比较。因此我们比较1和5,1比5小,所以我们就交换1和5,原来的排列就变成了“1,5,4,2,3 ” |
接下来,我们看第三个数字有没有在正确的位置。这个数字是4,temp=4,它的左边数字是5,4比5小,将5赋值给第三个数,排列变成了 “1,5,5,2,3 ",继续看第二个数字的左边,数字为1,比temp小,则把temp赋值给第二个数字,排列变成“1,4,5,2,3 "。 |
再来看第四个数字,这个数字是2,我们将2和它左边的数字相比,都比2大,所以就将2一路往左移动,一直移到2的左边是1,这时候排序变成了 “1,2,4,5,3 ” |
最后,我们检查第五个数字,这个数字是3,3必须往左移,一直移到3的左边是2为止,所以我们的排列就变成了“1,2,3,4,5 ”排序因此完成了。 |
所谓插入排序法,就是检查第i个数字,依次遍历它左边的数字,直到找到最后一个比它小的元素target,然后把它插入到target前面(注意每一次遍历时,比它大的元素都需要往后移动,即要执行list[in] = list[in - 1]这条语句) |
#include<iostream> using namespace std; //插入排序算法,n是元素个数,按从小到到顺序排序 void insertionSort(int list[], int n) { int in, out; for (out = 1; out < n; ++out) { in = out; int temp = list[out]; while (in>0 && list[in - 1] >= temp)//这个循环从out开始依次往左边遍历,比temp大的元素往后移动 { list[in] = list[in - 1]; //比temp大的元素往后移动 --in; } list[in] = temp;//将temp插入到对应的位置,完成一次插入排序 } } int main() { int a[] = { 5, 1, 6, 3, 8 }; insertionSort(a, 5); for (int k = 0; k < 5; k++) cout << a[k] << " "; system("pause"); return 0; }
相关文章推荐
- poj 3233Matrix Power Series(矩阵快速幂 二分求和 求累乘的和)
- ios开发之核心动画四:核心动画-Core Animation--CABasicAnimation基础核心动画
- 数学 求平行四边形的面积和坐标
- MyBatis学习之二:SQL语句映射文件(1)resultMap
- hadoop HA原理
- 浅析智能指针一
- xpath语法
- Python迭代器笔记
- 练习:WinForm 进程(创建、注销)
- gocode+auto-complete搭建emacs的go语言自动补全功能
- [bat] 批量删除文本文件的空行
- Python 学习笔记
- Android工具类--开关软键盘类
- Hololens入门之空间锚与场景保持
- 背包 贪心
- 网站前端_JavaScript-基础入门.0001.JavaScript简单概述
- Android内存泄漏产生的原因以及解决方案(OOM)
- 创建博客-文章编辑
- Leetcode 101. Symmetric Tree 验证树的对称性 解题报告
- 最全的机器学习资料汇总