QQ登录

只需一步,快速开始

快捷登录

登录 或者 注册 请先

UG爱好者

查看: 1629|回复: 1
打印 上一主题 下一主题

[原创] 测试C 希尔排序

[复制链接]

版主

超级无敌大帅哥:QQ哥

Rank: 10Rank: 10Rank: 10

10

主题

206

帖子

8672

积分

VIP会员论坛元老

跳转到指定楼层
楼主
发表于 2017-2-11 11:52:52 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
  1. //希尔排序
  2. #include "iostream.h"
  3. #include <process.h>
  4. //using namespace std;//使用命名空间时,要将头文件中的.h去掉
  5. #define N 50
  6. void shell_sort(int a[],int len)
  7. {
  8.     int h,i,j,temp;
  9.     for(h=len/2; h>0; h=h/2)//控制增量
  10.     {
  11.         for(i=h; i<len; i++)//这个for循环就是前面的直接插入排序
  12.         {
  13.             temp=a[i];
  14.             for(j=i-h; (j>=0&&temp<a[j]); j-=h)//循环打印数组的每个元素
  15.             {
  16.                 a[j+h]=a[j];
  17.             }
  18.             a[j+h]=temp;
  19.         }
  20.     }
  21. }

  22. void print_array(int a[], int len)
  23. {
  24.     for(int i=0; i<len; i++)
  25.     {
  26.         cout<<a[i]<<"";
  27.     }
  28.     cout<<endl;
  29. }

  30. void main()
  31. {
  32.     int a[N];
  33.     int b;
  34.     int M;
  35.     cout<<"请输入要排序的数目"<<endl;
  36.     cin>>M;


  37.     cout<<"请输入要排序的数"<<endl;
  38.     for(int i=0;i<M;i++)
  39.     {
  40.         cin>>b;
  41.         a[i]=b;
  42.     }
  43.     cout<<"beforeshellsort:";
  44.     print_array(a,M);
  45.     shell_sort(a,M);//进行shell排序
  46.     cout<<"aftershellsort:";
  47.     print_array(a,M);
  48.     //return0;
  49.     system("pause");
  50. }
复制代码

版权声明  
本人声明此帖为本人原创帖,未经允许,不得转载!

有奖推广贴子: 

喜欢吃QQ糖!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册会员

本版积分规则

 
 
QQ:1359218528
工作时间:
9:00-17:00
 
微信公众号
手机APP
机械社区
微信小程序

手机版|UG爱好者论坛 ( 京ICP备10217105号-2 )    论坛管理员QQ:1359218528

本站信息均由会员发表,不代表本网站立场,如侵犯了您的权利请联系管理员,邮箱:1359218528@qq.com  

Powered by UG爱好者 X3.2  © 2001-2014 Comsenz Inc. GMT+8, 2024-4-25 15:45

返回顶部