折半插入排序的基本思想是:设在顺序表中有一个对象序列V[0],V[1],…,V[n-1]。其中,V[0],V[1],…,V[i-1]是已经排好序的对象。在插入V[i]时,利用折半查找法寻找V[i]的插入位置。
折半插入排序源码
1
template<class Type>
2
void BinaryInsertSort(datalist<Type> &list){
3
for(int i=1;i<list.CurrentSize;i++) BinaryInsert(list,i);
4
};
5
6
template<class Type>
7
void BinaryInsert(datalist<Type> &list){
8
//利用折半查找,按list.Vector[i].key在list.Vector[0]到list.Vector[i-1]中
9
//查找list.Vector[i]应插入的位置,再空出这个位置进行插入。
10
int left=0,right=i-1;
11
Element<Type> temp = list.Vector[i];
12
while(left<=right){//利用折半查找插入位置
13
int middle = (left+right)/2;//取中点
14
if(temp.getKey()<list.Vector[middle].getKey())//插入值小于中点值
15
right = middle - 1;//向左缩小区间
16
else left = middle + 1;//否则,向右缩小区间
17
}
18
19
for(int k=i-1;k>=left;k--) list.Vector[k+1]=list.Vector[k];//成块移动空出插入位置
20
list.Vector[left]=temp;//插入
21
};
template<class Type> 2
void BinaryInsertSort(datalist<Type> &list){3
for(int i=1;i<list.CurrentSize;i++) BinaryInsert(list,i);4
};5

6
template<class Type> 7
void BinaryInsert(datalist<Type> &list){8
//利用折半查找,按list.Vector[i].key在list.Vector[0]到list.Vector[i-1]中9
//查找list.Vector[i]应插入的位置,再空出这个位置进行插入。10
int left=0,right=i-1;11
Element<Type> temp = list.Vector[i];12
while(left<=right){//利用折半查找插入位置13
int middle = (left+right)/2;//取中点14
if(temp.getKey()<list.Vector[middle].getKey())//插入值小于中点值15
right = middle - 1;//向左缩小区间16
else left = middle + 1;//否则,向右缩小区间17
}18

19
for(int k=i-1;k>=left;k--) list.Vector[k+1]=list.Vector[k];//成块移动空出插入位置20
list.Vector[left]=temp;//插入21
};折半插入排序源码



浙公网安备 33010602011771号