算法学习之插入排序
作者:互联网
一、总体思路
分成两个区域:排好序区(数组前面部分,绿色部分) + 待排序区(数组后面部分,黑色部分)。
不断将后面未排序区的数据往已排序区插入,使得已排序区不断扩大。
A | B | C | D | E | F | G | H |
初始时刻:已排序区只有一个数。
每趟:尝试将未排序区第一个元素插入已排序区,具体做法:从已排序区末尾元素开始往前遍历,若未排序区第一个元素比之小,则可以加入已排序区,且需从已排序区腾出一个位置出来。
A | B | C | D | E | F | G | H |
如上:A,B,C属于排好序区域,D及其之后为待排序区。将D及其之后的数据往A,B,C已排序区域插入。
二、优化
从后往前遍历排序区过程中,若已经比元素大,则不用再往前遍历了,因为更前面的数更小,可以提前退出本趟查找,不用将排序区遍历完。
三、代码
// 插入排序
void InsertSort(int arrayData[], int arraySize)
{
int i, j;
for (i = 0; i < arraySize - 1; i++) {
int tempValue = arrayData[i + 1];
int tempIdx = i + 1;
for (j = i; j >= 0; j--) {
if (tempValue < arrayData[j]) {
tempIdx = j;
arrayData[j + 1] = arrayData[j]; // 往后移动空出位置
} else if (tempValue > arrayData[j]) {
break; // 不用再往前比较了,前面存的更小
}
}
if (tempIdx != i + 1) {
arrayData[tempIdx] = tempValue;
}
}
}
标签:遍历,tempIdx,int,插入排序,学习,算法,tempValue,arrayData,排序 来源: https://blog.csdn.net/yi_wen/article/details/117171236