s1e21课后题最后一题,有人做了吗?好难理解不了,而且我照抄的代码打印出错!
检查不出来,,,怎么办啊,闹心 整不出来就不想向下学习!等会我上代码,大家帮我看看吧 代码上下看看。 本帖最后由 lizhiyong_11 于 2017-8-4 15:27 编辑ba21 发表于 2017-8-4 11:18
代码上下看看。
#include <stdio.h>
#include <stdbool.h>
int main()
{
int n, i, j, 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; i +=2)
{sum += j;
if (sum == cubed)
{
array = cubed;
array = i;
array = i +2;
array = j;
goto FINDIT;
}
if (sum > cubed)
{
sum = 0;
break;
}
}
}
FINDIT:
;
}
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;
}
一点一点从我的虚拟机上copy下来的,可以通过编译,但是有问题,请看下一楼的输出结果 xiaoyong@localhost s1e21]$ gcc task2.c && ./a.out
请输入一个整数:10
经验证,3~10 之间的所有整数均符合尼克斯定理!
是否打印所有等试(y/n):y
3^3 == 27 == 53 + 55 +1
4^3 == 64 == 73 + 75 +1
5^3 == 125 == 121 + 123 +1
6^3 == 216 == 181 + 183 +1
7^3 == 343 == 253 + 255 +1
8^3 == 512 == 337 + 339 +1
9^3 == 729 == 433 + 435 +1
10^3 == 1000 == 541 + 543 +1
$
请你帮我看一下,如果我输入的count是3,接下来定义了一个3行4列的数组,那么在第一个循环的时候,n = 3,那么数组arry不是表示第4行第1列的数吗?岂不是越界了? ba21 发表于 2017-8-4 15:08
关于 8的3次方,答案好像是错的
答案应该是:
8^3 == 512 == 17 + 19 +... + 47
页:
[1]