我收到错误“SIGSEGV on thread”。我怎么解决它?
#include <stdio.h>
int n[10], n2[10], num, nun, i=10, j=10, sv=0, on, res[4][20], opc[4][20];
main(){
printf("Insert the 1st number: ");
scanf("%d", &num);
sv = num;
while (num != 0)
{
n[i] = num%10;
num = num/10;
i--;
}
num = sv;
printf("Insert the 2nd number: ");
scanf("%d", &nun);
sv = nun;
while (nun != 0)
{
n2[j] = nun%10;
nun = nun/10;
j--;
}
nun = sv;
printf("Select an operation (1=addition; 2=subtraction; 3=multiplication; 4=division): ");
scanf("%d", &on);
while((on>4)||(on<0)){
printf("Try again: ");
scanf("%d", &on);
}
for (j=1; j<=8; j++){
for (i=20; i>=1; i--){
opc[j][i]=0;
}
}
if (on==1)
{
for (i=10; i>=1; i++)
{
if ((n[i] + n2[i] + opc[1][10+i]) <= 9)
{
opc[1][10+i] += (n[i] + n2[i]);
}
if ((n[i] + n2[i] + opc[1][10+i]) > 9)
{
opc[1][10+i] += (n[i] + n2[i])%10;
opc[1][9+i] += (n[i] + n2[i])/10;
}
}
}
else
{
printf("Coming soon :)");
}
}
答案 0 :(得分:2)
n [10]不是第一个循环中的有效下标。最后一个有效的下标比数组的大小小1(所以0 - 9)。您将从n [9](而不是10)开始并递减到n [0],因此将n和j更改为9:
n = 9;
j = 9;
您的2D阵列也是如此。每个维度的最后一个有效下标比大小(行/列)少一个。 opc [8] [20]不是有效的下标,这是你的for循环尝试访问的内容。