| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1067 人关注过本帖
标题:关于数组排序
只看楼主 加入收藏
小赵q1
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:4
帖 子:492
专家分:777
注 册:2011-8-26
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:16 
关于数组排序
关于数组排序的问题,实在是想不出来该怎么解决了,我也知道很简单的,
大家发表下意见。
我的要求是,给定一个数组,然后输入一个变量n控制数组中的前n个元素,让它们逆序排列输出;
我写的如下:
#include<stdio.h>
void main()
{
 int t,i,n,a[5]={1,2,3,4,5};
 scanf("%d",n);
 for(i=0;i<=n;i++)
 {t=a[n-i];
  a[i]=t;
  printf("%d",a[i]);
  }
 printf("\n");
}
输入3,它输出的结果是:4,3,3,4,到了(n+1)/2的地方不能还原为原来的值了。
如果把for语句里的那个条件换成i<(n+1)/2时,只能输出一半的结果,即输入3,输出的是4,3,后面的2,1不知道该用什么方法输出。
我主要是想用代换的方法解决这个问题,谢谢。

[ 本帖最后由 小赵q1 于 2011-10-2 02:36 编辑 ]
搜索更多相关主题的帖子: include 元素 
2011-10-02 01:39
Eg_a
Rank: 1
等 级:新手上路
帖 子:66
专家分:9
注 册:2011-4-23
收藏
得分:4 
#include<stdio.h>
void main(){
    int i;
    int a[5]={1,2,3,4,5};
    scanf("%d",&i);
    for(;i-1>=0;i--)                   //逆序输出
        printf("%d ",a[i-1]);
    printf("\n");
    getch();
}



[ 本帖最后由 Eg_a 于 2011-10-2 02:29 编辑 ]
2011-10-02 02:24
小赵q1
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:4
帖 子:492
专家分:777
注 册:2011-8-26
收藏
得分:0 
回复 2楼 Eg_a
能不能用代换的方法逆序输出呢?就是a[i]的值和a[n-i]的值互换;
2011-10-02 02:34
pauljames
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:千里冰封
威 望:9
帖 子:1555
专家分:10000
注 册:2011-5-8
收藏
得分:4 
#include<stdio.h>
void main()
{
int n,a[5]={1,2,3,4,5};
int *p=a;
scanf("%d",&n);
p=&a[n];
for(;p>=a;p--)
  printf("%d",*p);
printf("\n");
}

结果
4
54321

3
4321

2
321

经常不在线不能及时回复短消息,如有c/单片机/运动控制/数据采集等方面的项目难题可加qq1921826084。
2011-10-02 07:36
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
收藏
得分:0 
n是前n个元素,输入4时应是四个逆序,不是五个逆序。

授人以渔,不授人以鱼。
2011-10-02 12:09
larryliu
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:58
专家分:128
注 册:2011-9-30
收藏
得分:2 
建议用冒泡排序,很好用~~
2011-10-02 20:25
鸿飞冥冥
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:48
专家分:124
注 册:2011-8-14
收藏
得分:0 
好像是循环里少打一行  a[n-i]=a[i];

Sickcat
2011-10-02 21:26
lichuyang
Rank: 2
等 级:论坛游民
帖 子:7
专家分:11
注 册:2011-10-1
收藏
得分:4 
#include<stdio.h>
void main()
{
int t,i,n,a[5]={1,2,3,4,5};
scanf("%d",&n);
for(i=0;i<(n+1)/2;i++)
{
    t=a[i];
    a[i]=a[n-i-1];
    a[n-i-1]=t;
  }
for(i=0;i<=n-1;i++)
printf("%d",a[i]);
printf("\n");
}
2011-10-02 22:36
mengcan555
Rank: 4
等 级:业余侠客
帖 子:104
专家分:253
注 册:2011-9-17
收藏
得分:0 
楼上正解
2011-10-02 23:09
yangli0314
Rank: 3Rank: 3
来 自:重庆
等 级:论坛游侠
帖 子:101
专家分:142
注 册:2011-9-3
收藏
得分:3 
回复 6楼 larryliu
恩,冒泡法是比较简单而且很经典的算法,很多地方都要用
2011-10-03 00:08
快速回复:关于数组排序
数据加载中...
 
   



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

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