7-2 逆置一维数组
分数 10
全屏浏览题目
切换布局
作者 usx程序设计类课程组
单位 绍兴文理学院
编写程序,以指针的方式,就地逆置一维数组。
输入格式:
首先输入一个正整数T,表示测试数据的组数,然后是T组测试数据。每组测试数据先输入数据个数n,然后输入n个整数。
输出格式:
对于每组测试,在一行上输出逆置之后的结果。数据之间以一个空格分隔。
输入样例:
2 4 1 2 5 3 5 4 3 5 1 2
输出样例:
3 5 2 1 2 1 5 3 4
#include<stdio.h>
void sort(int a[],int n)
{
int temp=0;
for(int k=0;k<n/2;k++) //交换数组中对称的数的值
{
temp=*(a+k);
*(a+k)=*(a+n-1-k); //a+整数k=>a[0]开始后面的第k个元素(地址)
*(a+n-1-k)=temp; //相当于是&a[0]+整数,这里需要的则是该地址存放的值
}
}
int main()
{
int t;
scanf("%d",&t);
for(int i=0;i<t;i++)
{
int n;
scanf("%d",&n);
int a[n];
for(int j=0;j<n;j++)
{
scanf("%d",&a[j]);
}
sort(a,n); //数组名(a)就是数组⾸元素的地址
for(int j=0;j<n;j++)
{
printf("%d",a[j]);
if(j<n-1){printf(" ");}
}
if(i<t-1){printf("\n");}
}
return 0;
}
一维数组传参:本质上传递的是数组首元素的地址
数组名就是数组首元素(第一个元素)的地址。
例外情况:1、sizeof(数组名):这里数组名表示整个数组,计算的是整个数组的大小;
2、&数组名,这里的数组名表示整个数组,取出的是整个数组的地址,和其首元素地址不同。