从最后一个元素,逆向遍历到数组的0元素,逐一输出即可实现。
1、创建数组;
2、输入值;
3、逆序遍历输出数组。
代码:int main(){ int a[10]int i
for(i = 0 i < 10 i ++)
scanf("%d",a+i)
for(i = 9 i >= 0 i --)
printf("%d ", a[i])}
扩展资料:
将一个数组逆序输出。
1、程序分析:用第一个与最后一个交换。
2、程序源代码:
#define N 5
main()
{ int a[N]={9,6,5,4,1},i,temp
printf(" original array: ");
for(i=0i printf("%4d",a[i]);
for(i=0i {temp=a[i]
a[i]=a[N-i-1]
a[N-i-1]=temp
}
printf(" sorted array: ");
for(i=0i printf("%4d",a[i]);}
参考资料:百度百科 c语言
#include<stdio.h>void main()
{
int a[32],x,i,m
int change(int x,int a[])//函数声明
scanf("%d",&x)
m=change(x,a)
for(i=0i<mi++)
printf("%d",a[i])
}
int change(int x,int a[])//要和函数声明一致,所以后面也要填int x,int a[]
{
int n=0,t,k
do { a[n]=x%2
x=(unsigned int)x>>1//要考虑到参数int x有可能为负数所以填x=x/2是不行的。
//如果x>=0的话填x=x/2没有问题,实际上我估计这里出题者的本意希望填x/2,但是如果当x为负数的时候
//会出错的,要么填 x=(unsigned int)x/2也是可以的,不过 x=(unsigned int)x/2的运行效率远远低于x=(unsigned int)x>>1。这里牵涉的东西比较多,三言两语说不清
//如果想了解原因,建议回去看谭浩强的强制类型转换、正数和负数的2进制表示、移位3个知识点
n++
}while(x!=0)
//do...while()这个功能就是把这个数的二进制的位存入这个数组中
for(k=0k<n/2k++){
t=a[k]
a[k]=a[n-k-1]//实现数组中2个数交换
a[n-k-1]=t
//for循环是为了交换顺序,比如x=11是的二进制码是1011这4个码一次存在a[3] a[2] a[1] a[0]中,而输出的时候是按a[0] a[1] a[2] a[3]这样输出的如果没有这个交换屏幕上看到的会是1101
}
return n//返回值是数组中有用数据的个数
}
这个代码是经计算机运行验证的,绝对没有问题的,如果觉得好,请采纳,谢谢