| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 506 人关注过本帖
标题:请教一个关于数组排序的问题
取消只看楼主 加入收藏
大大猫
Rank: 1
等 级:新手上路
帖 子:44
专家分:0
注 册:2011-8-19
结帖率:81.25%
收藏
已结贴  问题点数:10 回复次数:1 
请教一个关于数组排序的问题
一个数组,如果有奇数个,则最大的放在中间,然后中间的左右分别从大到小排列,如果有偶数个,则放在中间右侧一个得位置,然后她的两侧分别从大到小排列;
例如:{1,2,3,4,5} 排序后为:{2,4,5,3,1}
      {1,2,3,4,5,6}排序后为:{1,3,5,6,4,2}
这个是考试题,我思考很久都没做上,特来求助,希望大家帮帮忙,谢谢
我就知道把最大的放中间了,之后的怎么办啊

搜索更多相关主题的帖子: 左右 考试题 最大的 
2011-09-06 23:03
大大猫
Rank: 1
等 级:新手上路
帖 子:44
专家分:0
注 册:2011-8-19
收藏
得分:0 
感谢大家的热心解答,我还有个疑问:你们怎么都说要分奇数和偶数呢?我排序时没分奇数和偶数的,中间位置都取得n/2;这样,奇数就是中间,偶数就是中间右侧一个得位置,下面是根据大家的思路我写的,再麻烦帮我看下,有没有什么不对的地方,再次感谢!!!
const int M =6;
int main()
{
   int a[M];
   void f(int a[],int n);
   int i;
   for(i=0;i<M;i++)
       cin>>a[i];
   f(a,M);
   return 0;
}
void  f(int a[],int n)
{
     int i,j,b[M],t;
     for(i=0;i<n-1;i++)
        for(j=0;j<n-1-i;j++)
             if(a[j]<a[j+1])
             {
                  t=a[j];a[j]=a[j+1];a[j+1]=t;
             }
     b[M/2]=a[0];
     for(i=1,j=M/2-1;i<n&&j>=0;i+=2,j--)
        b[j]=a[i];
     for(i=2,j=M/2+1;i<n&&j<M;i+=2,j++)
        b[j]=a[i];
     for(i=0;i<M;i++)
         cout<<b[i]<<"  ";
}
2011-09-07 10:32
快速回复:请教一个关于数组排序的问题
数据加载中...
 
   



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

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