鱼C论坛

 找回密码
 立即注册
查看: 3355|回复: 7

s1e21课后题最后一题,有人做了吗?好难理解不了,而且我照抄的代码打印出错!

[复制链接]
发表于 2017-8-4 10:53:38 From FishC Mobile | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
检查不出来,,,怎么办啊,闹心
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2017-8-4 10:54:39 From FishC Mobile | 显示全部楼层
整不出来就不想向下学习!等会我上代码,大家帮我看看吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-8-4 11:18:02 | 显示全部楼层
代码上下看看。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-8-4 12:37:42 | 显示全部楼层
本帖最后由 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[count][4];
        for (n = 3; n <= count; n++)
        {
                array[n][0] = 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[n][0] = cubed;
                                        array[n][1] = i;
                                        array[n][2] = i +2;
                                        array[n][3] = j;

                                        goto FINDIT;
                                }

                                if (sum > cubed)
                                {
                                        sum = 0;
                                        break;
                                }
                        }
                }
FINDIT:
                ;
        }
        for (n = 3; n <= count; n++)
        {
                if (array[n][0] == 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[n][3] - array[n][1] > 4)
                        {
                                printf("%d^3 == %d == %d + %d +...+%d\n", n, array[n][0], array[n][1], array[n][2], array[n][3]);
                        }
                        else
                        {
                                printf("%d^3 == %d == %d + %d +%d\n", n, array[n][0], array[n][1], array[n][2], array[n][3]);
                        }
                }
        }
        return 0;
}
一点一点从我的虚拟机上copy下来的,可以通过编译,但是有问题,请看下一楼的输出结果
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-8-4 12:41:43 | 显示全部楼层
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
[xiaoyong@localhost s1e21]$ 
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-8-4 15:08:25 | 显示全部楼层
2017-08-04_150634.png
2017-08-04_150552.png
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-8-4 15:33:59 | 显示全部楼层
请你帮我看一下,如果我输入的count是3,接下来定义了一个3行4列的数组,那么在第一个循环的时候,n = 3,  那么数组arry[3][0]不是表示第4行第1列的数吗?岂不是越界了?
temp.jpg
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-10-1 15:11:48 | 显示全部楼层

关于 8的3次方,答案好像是错的
答案应该是:
8^3 == 512 == 17 + 19 +... + 47
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-28 17:46

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表