有 5 6 7 8 9 的大小排序,自然也会有 9 8 7 6 5 的逆排序,
现在,编写一个函数,将一维数组中的数据逆序存放,
也就是数组倒序,一起来尝试一把吧!
#include <stdio.h>
void conarry(int x[],int n); /*n为数组大小 */
#define N 5
int main()
{
int a[N],i;
for(i=0;i<N;i++)
scanf("%d",&a[i]);
conarry(a,5); /*注意,5要与上面定义 n 的大小一致 */
for(i=0;i<N;i++)
printf("%d\t",a[i]);
}
void conarry(int x[],int n)
{
int i,t;
for(i=0;i<n/2;i++)
{
t=x[i];
x[i]=x[n-i-1];
x[n-i-1]=t;
}
}
很多小伙伴都会喜欢在 scanf 处漏掉 & 而导致出错,同时还要注
意 conarry 函数是否会造成内存错误,在 x[i]=x[n-i-1],这一步很容易出错,
容易忽略 i=0 时的情况,如果单单是 n-i ,那么当 i= 0时,就会发生越界
从而导致输出错误!