我没有在本地计算机上收到任何错误,但是codechef和ideone给出了运行时错误 我使用ubuntu和gcc 6.3 如果你有任何机会知道如何跟踪它,请告诉我,以便我可以将它用于我的进一步工作 继承人的代码
#include<stdio.h>
int main()
{
int n, m, i, x, j;
int a[n], b1, b2, b[n], c[m];
do
{
scanf("%d%d", &n, &m);
} while (!((1 <= n && n <= 100000) && (1 <= m && m <= 100000)));
for (i = 1; i <= n; i++)
{
do
{
scanf("%1d", &a[i]);
} while (!(0 <= a[i] && a[i] <= 9));
}
for (i = 1; i <= m; i++)
{
do
{
scanf("%d", &x);
} while (!(1 <= x && x <= n));
b1 = 0;
b2 = 0;
for (j = 1; j < x; j++)
{
b[j] = a[x] - a[j];
if (b[j] > 0)
b1 = b1 + b[j];
if (b[j] < 0)
b2 = b2 + b[j];
}
c[i] = b1 - b2;
}
for (i = 1; i <= m; i++)
printf("\n%d", c[i]);
return 0;
}
答案 0 :(得分:1)
问题是您是否正在尝试使用时间旅行来使您的代码正常工作。在下面的代码片段中,您使用稍后读取的值来声明数组,这显然无法正常工作。
int a[n], b1, b2, b[n], c[m];
do
{
scanf("%d%d", &n, &m);
相反,您应该将它们声明为int *
并为它们动态分配足够的空间。
int *a, b1, b2, *b, *c;
do
{
scanf("%d%d", &n, &m);
} while (!((1 <= n && n <= 100000) && (1 <= m && m <= 100000)));
a=malloc(sizeof(int)*n);
b=malloc(sizeof(int)*n);
c=malloc(sizeof(int)*m);
你需要记住释放后来分配的内存。
你还需要记住,C中的数组从索引0开始,而不是1,所以你可以在这里得到如下的循环:
for (i = 1; i <= n; i++)
do
{
scanf("%1d", &a[i]);
} while (!(0 <= a[i] && a[i] <= 9));
}
他们应该
for (i = 0; i < n; i++)
do
{
scanf("%1d", &a[i]);
} while (!(0 <= a[i] && a[i] <= 9));
}
因为如果i
等于n
,它将超出a
的大小。