C语言 把一个数组逆序输出

Python011

C语言 把一个数组逆序输出,第1张

从最后一个元素,逆向遍历到数组的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//返回值是数组中有用数据的个数

}

这个代码是经计算机运行验证的,绝对没有问题的,如果觉得好,请采纳,谢谢