| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 390 人关注过本帖
标题:数组排序的问题,谢谢!
只看楼主 加入收藏
bianchengxue
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2010-4-26
结帖率:50%
收藏
已结贴  问题点数:20 回复次数:2 
数组排序的问题,谢谢!

1. 写一个函数, 完成对一维数组的排序, 其排序要求如下: 将数组的最大值放在最右侧, 然后第二最大值放在最左侧, 第三最大值放在最大值的左侧, 第四最大值放在第二最大值的右侧,依次类推, 形式如下:  
数组值:       9  7  5  3  1  2  4  6  8  10
值的大小次序: 2  4  6  8 10  9  7  5  3   1

程序的屏幕输出形式如下:
排序前顺序为:
 10  9  8  7  6  5  4  3  2  1
排序后顺序为:
  9  7  5  3  1  2  4  6  8 10

Press any key to continue...
搜索更多相关主题的帖子: 函数 continue 最大值 
2010-05-02 19:32
jcslt
Rank: 8Rank: 8
来 自:90-xx.com
等 级:蝙蝠侠
帖 子:251
专家分:975
注 册:2009-10-10
收藏
得分:10 
#include<stdio.h>
#define MAX 10
void sort(int a[])
{
    int t,i;
    t=MAX/2,i=MAX-2;
    while(t--)
        printf("%d ",a[i]),i=i-2;
    if(i+2==0)i=1;
    else i=0;
    t=MAX/2+1-i;
    while(t--)
        printf("%d ",a[i]),i=i+2;
}
int main()
{
    int a[MAX],i,j,t;
    for(i=0;i<MAX;i++)
        scanf("%d",&a[i]);
    for(i=0;i<MAX;i++)
        for(j=i+1;j<MAX;j++)
        if(a[i]>a[j])
            t=a[i],a[i]=a[j],a[j]=t;
    sort(a);
    return 0;
}

www.
2010-05-02 20:32
xinhang
Rank: 2
等 级:论坛游民
帖 子:40
专家分:57
注 册:2006-7-25
收藏
得分:10 
#include<stdio.h>
#define size 10

int main()
{
  int a[size],b[size],t;
  
  for(int i = 0; i<size;i++)
    scanf("%d",&a[i]);

  for(int i = 0; i<size; i++)        /* 降序排序 */
    for(int j=i+1; j<size; j++)
      if(a[i]<a[j])
    {t=a[i]; a[i]=a[j]; a[j]=t;}

  for(int i = 0; i<size; i += 2)       /* 左右排序 */
      {b[9-i/2]=a[i]; b[i/2]=a[i+1];}
  
  for(int i = 0; i<size;i++)
    printf("%d ",b[i]);
  return 0;

}

[ 本帖最后由 xinhang 于 2010-5-3 14:54 编辑 ]

\" ﹏╭⌒╮¤ ﹋ ^^
2010-05-03 14:43
快速回复:数组排序的问题,谢谢!
数据加载中...
 
   



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

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