C程序输出错误,原因不明?
带你学C带你飞第一季第21指针课后习题的最后一个题目:https://fishc.com.cn/forum.php?mod=viewthread&tid=71653&extra=page%3D1%26filter%3Dtypeid%26typeid%3D570改进上一题的代码,用户输入一个表示范围的最大值 count,程序将测试 3 ~ count 所有的整数是否都符合尼科彻斯定理。
附加要求:有些用户可能不希望看到打印一丢丢式子,所以是否打印应该让用户确定(提示 -> 用二维数组先保存结果)。
我测试了小甲鱼的代码,输出结果如下图所示:
输出结果会出现一个奇怪的数字203004317,不知道是什么原因,请教大神指点。
测试环境是windows 10+codeblocks.
最后附上小甲鱼老师的源代码:
#include <stdio.h>
#include <stdbool.h>
int main()
{
int i, j, n, count, cubed, sum = 0;
bool result = true; // 用于存放验证结果
char answer;
printf("请输入一个整数:");
scanf("%d", &count);
int array;
// 变长数组无法再定义是初始化,只能手动了...
for (n = 3; n <= count; n++)
{
// 初始化第一列,因为后边用于验证
array = 0;
}
for (n = 3; n <= count; n++)
{
cubed = n * n * n;
for (i = 1; i < cubed; i += 2)
{
for (j = i; j < cubed; j += 2)
{
sum += j;
if (sum == cubed)
{
array = cubed;
array = i;
array = i + 2;
array = j;
goto FINDIT;
}
if (sum > cubed)
{
sum = 0;
break;
}
}
}
FINDIT:
sum = 0;
}
// 检查
for (n = 3; n <= count; n++)
{
if (array == 0)
{
result = false;
break;
}
}
if (result)
{
printf("经验证,3 ~ %d 之间所有的整数均符合尼科彻斯定理!\n\n", count);
printf("是否打印所有式子(y/n):");
getchar();
scanf("%c", &answer);
}
else
{
printf("验证失败:整数 %d 无法找到对应的连续奇数!\n");
}
if (answer == 'y')
{
// 打印
for (n = 3; n <= count; n++)
{
if (array - array > 4)
{
printf("%d^3 == %d == %d + %d +... + %d\n", n, array, array, array, array);
}
else
{
printf("%d^3 == %d == %d + %d + %d\n", n, array, array, array, array);
}
}
}
return 0;
} cben 发表于 2022-1-9 22:08
程序有多处报错,无法正常运行
我用的是vs,主要是告诉你如果动态数组count不加一会发生越界 我用dev没有问题
https://static01.imgkr.com/temp/e197754395614feda46f93303ecc62db.jpg{:10_245:} #include <stdio.h>
int main()
{
int i, j, n, count, cubed, sum = 0;
bool result = true; // 用于存放验证结果
char answer;
printf("请输入一个整数:");
scanf("%d", &count);
int (*array)=new int;//////////////////////////////////数组的count得加1,要不然后面 for (n = 3; n <= count; n++)都会越界
// 变长数组无法再定义是初始化,只能手动了...
for (n = 3; n <= count; n++)
{
// 初始化第一列,因为后边用于验证
array = 0;
}
for (n = 3; n <= count; n++)
{
cubed = n * n * n;
for (i = 1; i < cubed; i += 2)
{
for (j = i; j < cubed; j += 2)
{
sum += j;
if (sum == cubed)
{
array = cubed;
array = i;
array = i + 2;
array = j;
goto FINDIT;
}
if (sum > cubed)
{
sum = 0;
break;
}
}
}
FINDIT:
sum = 0;
}
// 检查
for (n = 3; n <= count; n++)
{
if (array == 0)
{
result = false;
break;
}
}
if (result)
{
printf("经验证,3 ~ %d 之间所有的整数均符合尼科彻斯定理!\n\n", count);
printf("是否打印所有式子(y/n):");
getchar();
scanf("%c", &answer);
}
else
{
printf("验证失败:整数 %d 无法找到对应的连续奇数!\n");
}
if (answer == 'y')
{
// 打印
for (n = 3; n <= count; n++)
{
if (array - array > 4)
{
printf("%d^3 == %d == %d + %d +... + %d\n", n, array, array, array, array);
}
else
{
printf("%d^3 == %d == %d + %d + %d\n", n, array, array, array, array);
}
}
}
delete[] array;
return 0;
} jhq999 发表于 2022-1-9 21:40
程序有多处报错,无法正常运行 jhq999 发表于 2022-1-9 22:17
我用的是vs,主要是告诉你如果动态数组count不加一会发生越界
您可以在codeblocks上测试吗?
页:
[1]