排序算法之插入排序法
来源:互联网 发布:淘宝开店怎么找货源 编辑:程序博客网 时间:2024/06/14 00:34
无论是C语言相关书籍还是算法等等,很多种书籍上都有介绍排序算法,而排序算法重要的在于它的思想,这也是一个程序的灵魂,相信大家也早都知道。在此,我简单介绍一下插入排序法的基本思想,以供一些初学者及掌握不深的学习人员作一个参考。
其中,插入排序法的核心思想是:
通过while的循环判断语句,从第二个数字开始,逐个向前一个数字对比,比较大小,若前两个按从小到大顺序排好后,第三个与前两个通过while判断,若大于前一个,则向前插一个位置,也可以理解为与前一个数字交换,交换后再继续与前一个数字比较,直到前一个数字比它小为止,停止比较。通过for语句,跳到下一个数字,继续前插循环比较。
#include<iostream>using namespace std;#define N 10void InsertSort(int *a, int n){int i, j, temp;for (i = 1; i < n; i++){temp = a[i]; //从第二个数开始,记住后一个数j = i - 1;while ( j >= 0 && temp < a[j]) //与前一个前插比较,若小于前一个数字{ //则将前一个数赋值给后一个数a[j + 1] = a[j]; //--j;}a[j+1] = temp; //将后一个记住的数赋给前一个数}}int main(){int i;int arr[N];for (i = 0; i < N;i++){cin >> arr[i];}InsertSort(arr, N);for (i = 0; i < N; i++){cout << arr[i];}return 0;}
其中,代码部分的while中必须利用temp来作为与前一个数比较的数字,若仍用a[i]来比较,则会出错,因为a[i]经过while比较赋值的过程已不再是原来的数字,这样便会出错。这是初学者容易出错的地方。也是我个人曾经犯过的错误。在此,希望能够给广大学习排序的学习者们给予帮助。
阅读全文
1 0
- java排序算法之(插入法排序)
- 常用排序算法之插入排序法
- 排序算法之简单插入排序法
- 排序算法之插入排序法
- 算法之【插入排序法】
- 排序算法之插入排序
- 排序算法之插入排序
- 排序算法之插入排序
- 排序算法之插入排序
- 排序算法之插入排序
- 排序算法之插入排序
- 排序算法之插入排序
- 排序算法之插入排序
- 排序算法之插入排序
- 排序算法之插入排序
- 排序算法之 插入排序
- 排序算法之插入排序
- 排序算法之插入排序
- bzoj 4032 [HEOI2015]最短不公共子串
- 蚁群算法(ACO)任务序列规划
- gdb
- Largest Rectangle in a Histogram(POJ No.2559) (栈的运用)
- 【慕课网】SEO在网页制作中的应用学习笔记
- 排序算法之插入排序法
- 文件IO
- 日志文件
- Libevent源码分析-----bufferevent工作流程探究
- Shiro Filter -- 拦截器
- python selenium api 源码查看方法
- Ubuntu 修改locale 把语言环境变量改为英文
- hdu 1008 elevator
- Python学习笔记(10) -- 回数(关键词:回文)