本题要求编写程序,将给定的n个整数存入数组中,将数组中的这n个数逆序存放,再按顺序输出数组中的元素。
输入格式:
输入在第一行中给出一个正整数n(1≤n≤10)。第二行输入n个整数,用空格分开。
输出格式:
在一行中输出这n个整数的处理结果,相邻数字中间用一个空格分开,行末不得有多余空格。
输入样例:
4
10 8 1 2
输出样例:
2 1 8 10
就觉得解题方式很厉害:将原本一开始的记录反其道行之,然后再按照正序输出!
#include<stdio.h>
int main(){
int n,i;
scanf("%d",&n);
int a[n];
for(i=n-1;i>=0;i--) {
//反着记录,因为序号从0开始,所以要先 -1,故a[n-1]表示第一个数
scanf("%d",&a[i]);
}
for(i=0;i<n;i++) {
printf("%d",a[i]);
//定义下的数组不会发生改变,所以可以直接输出
if(i<n-1) printf(" ");
}
return 0;
}
太绝啦!