SDUT OJ 3403数据结构实验之排序六:希尔排序

来源:互联网 发布:阿里云有香港主机 编辑:程序博客网 时间:2024/06/05 01:20

数据结构实验之排序六:希尔排序

Time Limit: 1000ms   Memory limit: 65536K  有疑问?点这里^_^

题目描述

我们已经学习了各种排序方法,知道在不同的情况下要选择不同的排序算法,以期达到最好的排序效率;对于待排序数据来说,若数据基本有序且记录较少时, 直接插入排序的效率是非常好的,希尔排序就是针对一组基本有序的少量数据记录进行排序的高效算法。你的任务是对于给定的数据进行希尔排序,其中增量dk=n/(2^k)(k=1,2,3……)

输入

连续输入多组数据,每组输入数据的第一行给出一个正整数N(N <= 10000),随后连续给出N个整数表示待排序关键字,数字间以空格分隔。

 

输出

输出dk=n/2和dk=1时的结果。

示例输入

1010 9 8 7 6 5 4 3 2 110-5 9 7 -11 37 -22 99 288 33 66

示例输出

5 4 3 2 1 10 9 8 7 61 2 3 4 5 6 7 8 9 10-22 9 7 -11 37 -5 99 288 33 66-22 -11 -5 7 9 33 37 66 99 288

#include<bits/stdc++.h>using namespace std;int a[10010];int n;void shellsort(int k){    int gap=k;    for(int j=gap; j<n; j++)    {        if(a[j-gap]>a[j])        {            int t=a[j];            int k=j-gap;            while(k>=0&&t<a[k])            {                a[k+gap]=a[k];                k-=gap;            }            a[k+gap]=t;        }    }}int main(){    while(cin>>n)    {        for(int i=0; i<n; i++)        {            cin>>a[i];        }        shellsort(n/2);        for(int i=0; i<n-1; i++)        {            cout<<a[i]<<" ";        }        cout<<a[n-1]<<endl;        shellsort(1);        for(int i=0; i<n-1; i++)        {            cout<<a[i]<<" ";        }        cout<<a[n-1]<<endl;    }    return 0;}

修改

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 yy频道提示禁止游客进入怎么办 口红颜色太艳了怎么办 我在菲律宾想走怎么办 当国家流通货币不够用怎么办 苹果5s账号密码忘记怎么办 钢铁雄心3补给不足怎么办 灯外观颜色太难看了怎么办 被移民公司骗了怎么办 文明5大包锁区怎么办 鸭子被黄鼠狼叼走了怎么办 黄鼠狼再店了拉屎怎么办 我只有信用卡但是又想去嫖怎么办 瑞士退税单掉了怎么办 装了新风噪音大怎么办 意大利 护照被偷了怎么办 请问去意大利要怎么办护照 在意大利护照丢了怎么办 考研二战档案打回原籍怎么办 脸上的肉往下掉怎么办 眼镜带了往下掉怎么办 孩子捅别的孩子眼睛了怎么办 眼睛不小心捅伤怎么办 我的爸爸是小偷怎么办 违停罚款忘记交怎么办 顺风车无人接单怎么办 来例假腰特别疼怎么办 把人撞死了全责怎么办 朝鲜与美合作对付中国怎么办 申请美国大学gpa不够怎么办 武装突袭3有地雷怎么办 辐射4狗肉跟丢了怎么办 洛奇英雄传死绑S怎么办 在老挝遇到坏人带枪怎么办 买了sd卡卡槽塞不下怎么办 现役军人家庭被邻居欺服怎么办 地铁买票买多了怎么办 免税店买的东西转机怎么办 绿能电动车坏了怎么办? 永久单车收不到验证码怎么办 24速山地车档乱了怎么办 新电瓶车被偷了怎么办