| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 994 人关注过本帖
标题:将N个数据按照从小到大的顺序排列。问题出在哪里?
只看楼主 加入收藏
粉jj
Rank: 2
等 级:论坛游民
威 望:1
帖 子:123
专家分:82
注 册:2011-3-8
结帖率:85.11%
收藏
 问题点数:0 回复次数:8 
将N个数据按照从小到大的顺序排列。问题出在哪里?
#define N 5
int R[N+5+1],d[4]={5,3,1,0};
SHELLSORT(int R[],int d[])
{int i,j,k=0,h,temp,maxint=32767;
for(i=0;i<d[0];i++)
R[i]=-maxint;
do{h=d[k];
for(i=h;i<N+5;i++)
{temp=R[i];
j=i-h;
while(temp<R[j+h])
{R[j+h]=R[j];j=j-h;}
R[j+h]=temp;
}
k++;}while(h!=1);}

main()
{int i;
for(i=1;i<=N;i++)
scanf("%d",&R[i+5+1]);SHELLSORT(R,d);
for(i=d[0];i<d[0]+N;i++)
printf("%d",R[i]);


           getch();}
2011-05-17 16:52
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:0 
格式太乱,看不懂。。。

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-05-17 17:02
其实、不想说
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:122
专家分:156
注 册:2011-3-3
收藏
得分:0 
太乱了没法看,你说下要实现什么功能???
2011-05-17 17:18
其实、不想说
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:122
专家分:156
注 册:2011-3-3
收藏
得分:0 
写代码注意缩格,还有就是要说明下!!
2011-05-17 17:19
hjywyj
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:3
帖 子:1114
专家分:2611
注 册:2010-4-14
收藏
得分:0 
太乱了,写的整齐点好不?
建议定义函数指针来做。
2011-05-17 17:20
lz1091914999
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:四川
等 级:贵宾
威 望:37
帖 子:2011
专家分:5959
注 册:2010-11-1
收藏
得分:0 
程序代码:
void swap(int * p1, int * p2) {
    *p1 ^= *p2;
    *p2 ^= *p1;
    *p1 ^= *p2;
}

void sortAscending(int * toBeSortArray, int arraySize) {
    int i, j, k;
    for(i = 0; i < arraySize - 1; i++) {
        k = i;
        for(j = i + 1; j < arraySize; j++) {
            if(toBeSortArray[j] < toBeSortArray[k]) {
                k = j;
            }
        }
        if(k != i) {
            swap(toBeSortArray + i, toBeSortArray + k);
        }
    }
}

My life is brilliant
2011-05-17 19:16
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
选择法  以后代码写清楚一些

                                         
===========深入<----------------->浅出============
2011-05-17 19:50
烟雾中的迷茫
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
帖 子:621
专家分:1069
注 册:2011-2-9
收藏
得分:0 
这个代码写的啊 ////
2011-05-17 21:37
粉jj
Rank: 2
等 级:论坛游民
威 望:1
帖 子:123
专家分:82
注 册:2011-3-8
收藏
得分:0 
#define N 5
int R[N+5+1],d[4]={5,3,1,0};
SHELLSORT(int R[],int d[])
{
    int i,j,k=0,h,temp,maxint=32767;
     for(i=0;i<d[0];i++)
        R[i]=-maxint;
  do
   {
        h=d[k];
          for(i=h;i<N+5;i++)
          {  
              temp=R[i];
                 j=i-h;
                  while  (temp<R[j+h])
                     {   R[j+h]=R[j];j=j-h;  }
              R[j+h]=temp;
           }
         k++;
    }while(h!=1);
}

main()
{int i;
for(i=1;i<=N;i++)
scanf("%d",&R[i+5+1]);
SHELLSORT(R,d);
for(i=d[0];i<d[0]+N;i++)
  printf("%d",R[i]);
           getch();}
2011-05-17 22:00
快速回复:将N个数据按照从小到大的顺序排列。问题出在哪里?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.079818 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved