排序算法总结(二)插入排序

访问www.tomcoding.com网站,学习Oracle内部数据结构,详细文档说明,下载Oracle的exp/imp,DUL,logminer,ASM工具的源代码,学习高技术含量的内容。

插入排序是在一个有序集合中插入一个元素,插入后这个集合还是有序状态。如果一个数组本来是无序的,要用插入排序算法使之有序,这个过程就叫插入排序。这个算法要点在于要先有一个排过序的集合,如果把第一个元素看做是有序的,那么这个集合就有了,接下来就是在剩下的元素中遍历一次,把每个元素插入到前面的有序集合中。

如果数组的元素个数是n,我们看看在第i个元素插入时的状态,这时i元素之前的所有元素都是从小到大排过序的,从有序集合的最后一个元素依次往前搜索,找到一个前一个元素比i元素小,本元素比i元素大的位置,把i元素插入这个元素之前。这里有一个问题,由于数组元素是紧密排列的,要插入元素,就需要一个空位置,这个位置是在往前搜索过程中,逐个把元素往后移一个位置,覆盖i元素后腾出来的。

用C语言写一个函数实现这个算法。

void insertion_sort(int *ai, int n)

{

int i, j;

int ei;

/* 0元素是有序的,从1开始遍历数组中的其他元素,插入有序集 */

for (i = 1; i < n; i++) {

/* 保存当前的元素值,因为要往后移动元素,会覆盖当前元素 */

ei = ai[i];

/* i-1的元素就是有序集合中的最后一个元素,往前搜索 */

for (j =i-1; j >= 0; j--) {

if (ai[j] < ei)

/* 找到比当前元素小的位置,终止循环 */

break;

/* 当前元素比有序集合中的j元素小,往后移动j元素

* 第一个循环时,ai[j+1]就是ai[i]元素,被覆盖掉

* 后续循环,前一个元素把后一个元素覆盖

*/

ai[j+1] = ai[j];

}

/* ai[j]比当前元素小或相等,那么ai[j+1]就是移动后空出来的位置 */

ai[j+1] = ei;

}

}

其实一个一个的往后移动元素,还是很耗费资源的,我们可以找到插入的位置,然后把需要移动的元素一次性的往后移动一个位置。修改一下程序如下。

static void insertion_sort(int *ai, int n)

{

int i, j;

int ei;

for (i = 1; i < n; i++) {

ei = ai[i];

/* 可以从头查找,不用倒序查找 */

for (j = 0; j < i; j++) {

if (ai[j] > ei)

/* 找到比当前元素大的位置,退出循环 */

break;

}

/* 移动元素,空出插入的位置 */

memmove(&ai[j+1], &ai[j], (i-j)*sizeof(int));

ai[j] = ei;

}

}

相关推荐
PHASELESS4111 小时前
Java排序算法百科全书:原理、实现与实战指南
java·数据结构·算法·排序算法
学习编程的gas2 小时前
数据结构——八大排序算法
数据结构·算法·排序算法
暖阳华笺2 小时前
Leetcode刷题 由浅入深之哈希表——242. 有效的字母异位词
数据结构·c++·算法·leetcode·哈希表
Smark.2 小时前
数据结构之BFS广度优先算法(腐烂的苹果)
数据结构·算法·宽度优先
代码程序猿RIP3 小时前
C++(22)—内存管理
开发语言·数据结构·c++·算法
八股文领域大手子4 小时前
深入浅出 Redis:核心数据结构解析与应用场景Redis 数据结构
java·数据结构·数据库·人工智能·spring boot·redis·后端
一只专注api接口开发的技术猿4 小时前
基于 Java 的淘宝 API 调用实践:商品详情页 JSON 数据结构解析与重构
大数据·数据结构·重构·json
可乐^奶茶5 小时前
2026《数据结构》考研复习笔记二(C++面向对象)
数据结构·c++·笔记
槐月杰8 小时前
C语言中冒泡排序和快速排序的区别
c语言·算法·排序算法
奋进的小暄9 小时前
数据结构(java)栈与队列
java·开发语言·数据结构