今天首先来做一个题,值得借鉴。
#include<stdio.h>
void fun(int *p){
printf("%d",p[5]);//打印第六个元素,但是地址传入的第四个元素,
getchar();
}
void main()
{
int a[10] = {1,2,3,4,5,6,7,8,9,10};
fun(&a[3]); //把数组的第4个元素的地址传入进去
}
// 最后打印的元素的是9 a[3+5]是第九个元素。
我们还有一点值得注意的是,即便传递的数组中的一个元素的地址,也可以传递数组中的其他元素,应为该元素地址已经帮指针定位到数组的某一位置,也可以通过这个位置来推断其他元素的位置。
今天的第二题的是,如何在数组倒序输出
#include<stdio.h>
#include<stdlib.h>
//解题思路。讲a[0]与a[n-1]互换
//a[4]和a[5]互换
void main()
{
int n = 5; int a[5] = { 2, 4, 5, 7, 8 };
int i;
// 依次交换首尾元素,直到中间的数字
for(i=0;i<n/2;i++)
{
int t = a[i];
a[i] = a[n - 1 - i];
a[n - 1 - i] = t;
}
for (int j = 0; j < 5; j++)
{
printf("%d", a[j]);
}
getchar();
system("psuse");
}