同样,a[i][j]也可使用指针下标法表示,如p[i*N+j]。
设二维数组为typename a[M][N],则指向该数组的指针为typename (*p)[N]= a;这样就可以用p来代替二维数组了。
也就是说,我们可以用数组名来初始化一个对应类型的指针。虽然数组名是指针,但它是一个指针常量。也就是说,不带下标的数组名不能作为左值。指针是一种数据类型,所以,我们可以用指针类型来创建一个数组。
只有这样\x0d\x0aint *w,a[44];\x0d\x0aw=a;\x0d\x0a操作后才可以,操作w就与操作a一样了。而且,操作指针比直接操作数组名更方便,因为指针是变量,可以++、--,而数组名是常量,不能++、--。
数组指针定义int(*p)[n];()优先级高,首先说明p是一个指针,指向一个整型的一维数组,这个一维数组的长度是n,也可以说是p的步长。也就是说执行p+1时,p要跨过n个整型数据的长度。
[]:一般用于C语言的数组,里面是数组的下标。
在C语言中,下标定义为数组arr[]和数组brr[n]。下标用于数组中。arr[1]和brr[1]是下标相同的元素。当数组arr[1]中的数字满足条件时,将执行移位计算。C语言是向左移动减少,向右移动增加。
c语言中,数组元素的下标下限为0。 数组中的各元素的存储是有先后顺序的,它们在内存中按照这个先后顺序连续存放在一起。数组元素用整个数组的名字和它自己在数组中的顺序位置来表示。
C语言数组的下标只能是合法的整型值。当下标为字符时,有两种可能:1 以字符常量作为下标。如a[A];表示A的ascii码对应的数组偏移量。在实际应用中不常见,但是从语法上来说是合法的。2 字符本身为变量。
下标可以是变量 也可以是常量。直接说a[0],a[1],a[2],a[3]这样的下标就是常量。
首先输入头文件以及主函数框架后,我们定义变量,并初始化。然后我们就可以输入printf准备输出。但是,这个时候,我们格式控制符就有区别了,我们应该输入【%P】。然后我们输入我们要输出的指针。
应为a是一个指向指针的指针,它指向的是和自己存储的地址相同的指针,即a[0],a[0]是第一行一维数组的指针,可以指向具体变量。
首先你要明白一点,数组名和指针本质上是一回事,都是地址,该数组的首地址。知道这一点后就可以活学活用了。这是c语言的精髓。
int (*p)[4]这个就能当做二维数组的指针,第二维的长度得是4。
这个指针也是指向数组的,数组有n个元素,每个元素不是int,而是指针int*;这个指针是int**p; 又如何声明一个指针,它指向另一个指针,这“另一个指针”指向一个数组,数组元素是int;这个指针仍然是int**p。
int a[10]={1,2,3,4,5,6,7,8,9,0};int b = 0;b = fun(a,10);printf(The max number is a[%d] = %d\n, b,k);getch();} K定义为全局变量。
自定义一个函数void Input_Max_Min(int *p,int *pl,int *ps)来完成题设要求,其中p是数组首指针,pl是最大值位置(下标)变量指针,ps是最小值位置(下标)变量指针。在主函数中输出结果。
for(i=1;iN;i++) 数组下标是 0开始的。 不是1 。 1就不对了。
void fun(){ int a,b,c;a=7;b=8;c=a+b;printf(这个fun()函数的功能就是计算a+b的值。c=%d\n,c);} C/C++语言中,fun函数通常被主函数所调用。
关于c语言用指针获取数组下标,以及c语言获取指针的值的相关信息分享结束,感谢你的耐心阅读,希望对你有所帮助。
上一篇
编程c语言初学
下一篇
数组的输入输出c语言