Chinaunix首页 | 论坛 | 博客
  • 博客访问: 25271
  • 博文数量: 14
  • 博客积分: 600
  • 博客等级: 中士
  • 技术积分: 165
  • 用 户 组: 普通用户
  • 注册时间: 2008-11-05 11:28
文章分类

全部博文(14)

文章存档

2011年(1)

2009年(3)

2008年(10)

我的朋友

分类: C/C++

2008-12-18 17:24:56

#include
#include

int shell_sort(int array[], int size)
{
    int temp, step, i, flag = 1;
    step = size / 2;
    do
    {
        flag = 0;
        for (i = 0; i + step < size; i++)
        {
            if (array[i] > array[i + step])
            {
                temp = array[i];
                array[i] = array[i + step];
                array[i + step] = temp;
                flag = 1;
            }
        }
        if ((step == 1) && (flag ==1))
            continue;
        step /= 2;
    }while((flag == 1) || (step > 0));
}
int main(void)
{
    int values[30], i;
    for (i = 0; i < 30; i++)
    {
        values[i] = rand()%100;
        printf("%d ", values[i]);
    }
    shell_sort(values, 30);
    printf("\n");    
    for (i = 0; i < 30; i++)
        printf("%d ",values[i]);
    return 0;
}
阅读(495) | 评论(0) | 转发(0) |
0

上一篇:冒泡排序

下一篇:选择排序

给主人留下些什么吧!~~