{inta[] = {1,3,4};int*p = &a[-1];inti =0;for( i =1; i <4; i++) { printf("%d\n", p[i]); } } 因为数组并不检查下表是否越界,下表仅表示偏移, -1就表示第一个元素前面那个元素 例子2 在 头文件 stdarg.h 中,有如下宏定义: typedef char* list; va_arg #define va_arg(li...
int a[] = {1,3,4};int *p = &a[-1];int i =0;for( i = 1; i <4; i++){ printf("%d\n", p[i]);} } 因为数组并不检查下表是否越界,下表仅表⽰偏移, -1就表⽰第⼀个元素前⾯那个元素 例⼦2 在头⽂件 stdarg.h 中,有如下宏定义:typedef char* list;va_arg #...
{inta[] = {1,3,4};int*p = &a[-1];inti =0;for( i =1; i <4; i++) { printf("%d\n", p[i]); } } 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 因为数组并不检查下表是否越界,下表仅表示偏移, -1就表示第一个元素前面那个元素 例子2 在 头文件 stdarg.h 中,有如下宏定义...
C/C++ 从数组负数下标开始 如果我们定义一个长度为n的数组,那么理论上下标的范围为[0,n−1]。 但是实际上,在C/C++中,数组的下标可以是负数,而且是可以通过编译的。 intarr[]={1,2,3,4};intnum=arr[-3]; 这里需要明确,C/C++ 是不会检查下标时候合法。 因为C要追求速度,如果他要检查下标,就需要在...
C语言计算中得出-1.#indoo的原因是溢出类问题 C语言计算中得出-1.#indoo的原因一般有两类 第一类:数组下标溢出问题,例如数组出现负数的下标 第二类:数据类型上面的溢出,你如果求幂或者费伯拉西数列的时候,项数大很容易引发溢出,float类型数据溢出就报-1.#indoo这个错误.include <stdio.h> main() {...
这个-1操作,是返回当前指针前一个值。如果你熟悉c++中内存模型就应该明白。array 在内存栈或者堆中是连续的一段空间。 如果我们对一个数组 int a[10]进行a[-1]操作,那么就可能出现错误,因为我们这时候出现了不可控的指针操作,返回的值是不可预料的。
01数组的下标可以是负数 C语言中使用数组,一般来说都是这样的: inta[5]={1,2,3,4, 5}; a[0] = 10; 语法规定,数组的长度必须是个常量,保证数组所占的内存大小不变。数组下标从 0 开始,依次往后递增。于是大部分同学都把它当作了默认的规则。 其实,数组的长度可以是0,叫做柔性数组,目的是让结构体变成...
{ scanf("%d",&input); arr[i] = input; } for (int j=0; j<len; j++){ if (arr[j] == data) { ret = j; break; } } printf("\n%d", ret);}
C语言规定数组是有下标的,下标是从0开始的,假设数组有n个元素,最后一个元素的下标是n-1,下标就相当于数组元素的编号,如下: 代码语言:javascript 复制 int arr[10]={1,2,3,4,5,6,7,8,9,10}; 代码语言:javascript 复制 数组元素和下标 在C语言中数组的访问提供了一个操作符 [ ] ,这个操作符叫:下标...
数组下标的主要作用是方便地访问和操作数组中的元素。通过指定下标,可以轻松地读取或修改数组中的特定元素。比如,要访问数组arr的第一个元素,我们需要使用下标0,即arr[0]。同样地,若要修改这个元素的值,也可以直接通过arr[0]进行操作。在实际编程中,正确使用数组下标至关重要。错误的下标会导致数组...