浅汐ゞ 2023-03-23 22:33 采纳率: 100%
浏览 36
已结题

C语言数组的定义赋值运算


#include<stdio.h>
int main(){
 int sum=0,i=0;
 float aver=0.0;
 int a[i];
 int max=0;
 for(i=0;i<=49;i++){
   scanf("%d",&a[i]);
 }
 max=a[0];
 for(i=0;i<=49;i++)
 {
 if(a[i]>max)
 max=a[i];
 sum+=a[i];
}
 aver=sum/50;
 printf("%d,%f",max,aver);
 return 0;
}
为什么编译的时候没出错,但是运行不出来啊。但如果把5049改成54就可以运行了。这是怎么一回事啊?


  • 写回答

2条回答 默认 最新

  • IT_service_mesh 2023-03-23 22:54
    关注

    参考GPT和自己的思路:

    问题出在这一行代码上:

    int a[i];
    

    在定义数组时,你使用了变量 i 来指定数组的长度。但是在这个时候,i 的值还没有被初始化,它是随机的。所以,当你试图访问 a[0] 到 a[49] 时,程序可能会试图访问未分配的内存,导致运行时错误。

    当你将数组长度改为 5 和 4 时,它们的值是已知的,因此不会有这个问题。

    要解决这个问题,你可以在读取输入之前将 i 初始化为数组的长度,或者使用固定的数组长度。例如:

    #define ARRAY_LENGTH 50
    int a[ARRAY_LENGTH];
    
    // 或者
    
    int i, a[50];
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 3月23日
  • 已采纳回答 3月23日
  • 创建了问题 3月23日