| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1353 人关注过本帖, 1 人收藏
标题:求解各位这个逆序排序是怎么改?
只看楼主 加入收藏
这样挺好
Rank: 1
等 级:新手上路
帖 子:8
专家分:2
注 册:2017-11-27
结帖率:50%
收藏(1)
已结贴  问题点数:20 回复次数:5 
求解各位这个逆序排序是怎么改?
本题要求编写程序,将给定的n个整数存入数组中,将数组中的这n个数逆序存放,再按顺序输出数组中的元素。
输入格式:
输入在第一行中给出一个正整数n(1≤n≤10)。第二行输入n个整数,用空格分开。
输出格式:
在一行中输出这n个整数的处理结果,相邻数字中间用一个空格分开,行末不得有多余空格。
输入样例:
4
10 8 1 2
输出样例:
2 1 8 10
#include <stdio.h>
int main(int argc, char *argv[])
{
    int n,a[10],i,j,k;
    printf("请输入一个数字n:");
    scanf("%d",&n);
    printf("请输入n个数字: ");
    for(i=0;i<n;i++)
      scanf("%d",&a[i]);   
       for(i=0,j=n-1;i<j;i++,j--)
      {
          k=a[i];
         a[i]=a[j];
         a[j]=k;
      }            
    for(i=0;i<n;i++)
       printf("%d ",a[i]);
    printf("\n");
    return 0;
}
中的for(i=0,j=n-1;i<j;i++,j--)这个还可以怎么改?求解
搜索更多相关主题的帖子: 输出 输入 printf for i++ 
2017-11-27 16:52
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:10 
比较常规的写法:

程序代码:
int main(int argc, char *argv[])

 {
     int n,a[10],i,j,k;
     printf("请输入一个数字n:");
     scanf("%d",&n);
     if(n>10)
     {
         printf("超出范围.\n");
         return 0;
     }
     printf("请输入%d个数字: ",n);
     for(i=0;i<n;i++)  scanf("%d",&a[i]);    
     for(i=0;i<n;i++)  printf("%d ",a[n-i-1]);
     printf("\n");
     return 0;

 }

DO IT YOURSELF !
2017-11-27 16:58
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
啊 没有看到逆序存放  2楼代码pass掉吧

DO IT YOURSELF !
2017-11-27 17:02
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:10 
程序代码:
int main(int argc, char *argv[])

 {
     int n,a[10],i;
     printf("请输入一个数字n:");
     scanf("%d",&n);
     if(n>10)
     {
         printf("超出范围.\n");
         return 0;
     }
     printf("请输入%d个数字: ",n);
     for(i=0;i<n;i++)  scanf("%d",&a[i]);  
     int j=0;
     int k=n-1;
     int tmp;
     while(k>=j)
     {
         tmp=a[j];
         a[j]=a[k];
         a[k]=tmp;
         j++;
         k--;
     }
     for(i=0;i<n;i++)  printf("%d ",a[i]);
     printf("\n");
     return 0;

 }

DO IT YOURSELF !
2017-11-27 17:06
这样挺好
Rank: 1
等 级:新手上路
帖 子:8
专家分:2
注 册:2017-11-27
收藏
得分:0 
回复 2楼 wp231957
你的"j",没有用到,反而占了存储空间
2017-12-02 09:34
银贼娃
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2017-12-2
收藏
得分:0 
回复 楼主 这样挺好
#include<stdio.h>
int main()
{
    int n,i,a[10];
    scanf("%d",&n);
    for(i=0;i<n;i++)

        scanf("%d",&a[i]);


    for(i=n-1;i>=0;i--)
    printf("%d ",a[i]);
    return 0;
}
2017-12-02 11:30
快速回复:求解各位这个逆序排序是怎么改?
数据加载中...
 
   



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

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