64,654
社区成员
发帖
与我相关
我的任务
分享
template<typename T>
void ShellSort(T data[],int arrSize)//希尔排序
{
T tmp;
int i,j,hCnt,h,k;
const int num(8);
int increments[num];//间隔数
for(h=1,i=0;h<arrSize&&i<num;++i)
{
increments[i]=h;
h=3*h+1;
}
for(--i;i>=0;--i)
{
h=increments[i];
for(hCnt=h;hCnt<2*h;++hCnt)
{
for(j=hCnt;j<arrSize;)
{
tmp=data[j];
k=j;
while(k-h>=0&&tmp<data[k-h])
{
data[k]=data[k-h];
k-=h;
}
data[k]=tmp;
j+=h;
}
}
}
}
void CShxBigfont::SortIndex(void)
{
//对索引区进行排序,排序之后可以使用二分法进行快速检索
bool bFinish; //结束标志
int iSpace = ShapeCount; //起始跨度
CBigfontIndex siTemp; //临时索引项,用于交换
while(iSpace)
{
bFinish = false; //结束标志初始化
iSpace /= 2; //跨度减半
while(!bFinish)
{
bFinish = true; //假定即将结束
for(int i=0;i<ShapeCount-iSpace;i++)
{
if(ShapeIndex[i]>ShapeIndex[i+iSpace])
{
//需要交换
siTemp = ShapeIndex[i];
ShapeIndex[i] = ShapeIndex[i+iSpace];
ShapeIndex[i+iSpace] = siTemp;
bFinish = false; //设定结束标志
}
}
}
}
}