待排序记录序列的存储结构待排序记录序列可以 用顺序存储结构和和链式存储结构表示。在本章的讨 论中(除基数排序外),我们将待排序的记录序列用 顺序存储结构表示,即用一维数组实现。其定义如下 所示: define maX num80∥待排序记录序列中的最大数 据元素个数 typedef struct elemtype{∥(排序的数据元素类型 keytype key: 数据元素的关键字 anytype otheritem;/数据元素中的其他成份 )Data Type MAX NUM+l 请单赤鼠标左键换页!
待排序记录序列的存储结构 待排序记录序列可以 用顺序存储结构和和链式存储结构表示。在本章的讨 论中(除基数排序外),我们将待排序的记录序列用 顺序存储结构表示,即用一维数组实现。其定义如下 所示: #define MAX_NUM 80 //待排序记录序列中的最大数 据元素个数 typedef struct elemtype { //待排序的数据元素类型 keytype key; //数据元素的关键字 anytype otheritem; //数据元素中的其他成份 }DataType[MAX_NUM+1];
8.2插入排序 插入排序的主要思路是不断地将待排序的数值插 入到有序段中,使有序段逐渐扩大,直至所有数值都 进入有序段中位置。 8.2.1直接插入排序 1.直接插入排序的基本思想 请单赤鼠标左键换页!
8.2 插入排序 插入排序的主要思路是不断地将待排序的数值插 入到有序段中,使有序段逐渐扩大,直至所有数值都 进入有序段中位置。 8.2.1 直接插入排序 1. 直接插入排序的基本思想
直接插入排序是一种比较简单的排序方法。它的 基本思想是依次将记录序列中的每一个记录插入到有 序段中,使有序段的长度不断地扩大。其具体的排序 过程可以描述如下:首先将待排序记录序列中的第 个记录作为一个有序段,将记录序列中的第二个记录 插入到上述有序段中形成由两个记录组成的有序段, 再将记录序列中的第三个记录插入到这个有序段中, 形成由三个记录组成的有序段,…依此类推,每一趟 都是将一个记录插入到前面的有序段中,假设当前欲 处理第个记录,则应该将这个记录插入到由前i-1个记 录组成的有序段中,从而形成一个由个记录组成的按 关键字值排列的有序序列,直到所有记录都插入到有 序段中。一共需要经过n-趟就可以将初始序列的n个 记录重新排列成按关键字值大小排列的有序序列 请单赤鼠标左键换页!
直接插入排序是一种比较简单的排序方法。它的 基本思想是依次将记录序列中的每一个记录插入到有 序段中,使有序段的长度不断地扩大。其具体的排序 过程可以描述如下:首先将待排序记录序列中的第一 个记录作为一个有序段,将记录序列中的第二个记录 插入到上述有序段中形成由两个记录组成的有序段, 再将记录序列中的第三个记录插入到这个有序段中, 形成由三个记录组成的有序段,…依此类推,每一趟 都是将一个记录插入到前面的有序段中,假设当前欲 处理第i个记录,则应该将这个记录插入到由前i-1个记 录组成的有序段中,从而形成一个由i个记录组成的按 关键字值排列的有序序列,直到所有记录都插入到有 序段中。一共需要经过n-1趟就可以将初始序列的n个 记录重新排列成按关键字值大小排列的有序序列
2.直接插入排序算法 将第个记录插入到由前面i1个记录构成的有序段 中主要有两个步骤: (1)将待插入记录a保存在a0中,即a0=a[i; 2)搜索插入位置: j=i-l;最初指示的前一个位置 while(ajo. key <alj. key) ai+1}=ajl;∥后移关键字值大于a|01key的记录 /将指向前一个记录,为下次比较做准备 a+1=a|0;/将a0放置在第j+1个位置上 请单鼠标左键换页!
2. 直接插入排序算法 将第i个记录插入到由前面i-1个记录构成的有序段 中主要有两个步骤: ⑴ 将待插入记录a[i] 保存在a[0]中,即a[0]=a[i]; ⑵ 搜索插入位置: j=i-1; //j最初指示i的前一个位置 while (a[0].key <a[j].key) { a[j+1]=a[j]; //后移关键字值大于a[0].key的记录 j=j-1; //将j指向前一个记录,为下次比较做准备 } a[j+1]=a[0]; //将a[0]放置在第j+1个位置上
完整的插入排序算法为: void insertsort (Data Type a, int n) for(i=2; i<=n; i++) ∥:要n-1趟 a|0}=ai;∥将a[赋予监视哨 while(al0key< alj. key)搜索插入位置 i alj+1=all; jj-1; ai+1|=a0;∥将原a中的记录放入第+个位置 请单赤鼠标左键换页!
完整的插入排序算法为: void insertsort (DataType a, int n) { for (i=2; i<=n; i++) //需要n-1趟 { a[0]=a[i]; //将a[i]赋予监视哨 j=i-1; while (a[0].key<a[j].key) //搜索插入位置 { a[j+1]=a[j]; j=j-1; } a[j+1]=a[0]; // 将原a[i]中的记录放入第j+1个位置 } }