鱼C论坛

 找回密码
 立即注册
查看: 2382|回复: 10

[已解决]S1E21课后作业第1题

[复制链接]
发表于 2022-9-9 23:57:50 | 显示全部楼层 |阅读模式
15鱼币
本帖最后由 须弥芥子 于 2022-9-10 00:00 编辑

为什么单独512出问题?
  1. /*************************************************************************
  2.     > File Name: 1plus.c
  3.     > Author: Yanjl
  4.     > Mail: miku.cy@foxmail.com
  5.     > Created Time: 2022/9/9 22:51:57
  6. ************************************************************************/

  7. #include<stdio.h>
  8. #define MAX 1024
  9. int main(){

  10.         int num, sum, count;
  11.         int numList[MAX][3];
  12.         //当数字个数>3时用冒号省略
  13.         _Bool shengLue[MAX];
  14.         int lifNum[MAX];
  15.         _Bool fuHe = 1;
  16.         //j用于写入输出数字
  17.         int j = 0;
  18.         //k是数字位次
  19.         int k = 0;
  20.         count = 3;

  21.         sum = 0;

  22.         printf("请输入一个整数:");

  23.         scanf("%d",&num);

  24.         for(int z = 3; z <= num; z++){
  25.                 lifNum[k] = z * z * z;
  26.                 for(int i = 1; ; i += 2){
  27.                         sum += i;
  28.                         if(j <= 2){
  29.                                 numList[k][j] = i;
  30.                                 shengLue[k] = 0;
  31.                                 j++;
  32.                         }else{
  33.                                 numList[k][2] = i;
  34.                                 shengLue[k] = 1;
  35.                         }
  36.                         if(sum == lifNum[k]){
  37.                                 k++;
  38.                                 break;
  39.                         }
  40.                         if(sum > lifNum[k]){
  41.                                 j = 0;
  42.                                 i = (count += 2);
  43.                                 sum = 0;
  44.                                 shengLue[k] = 0;
  45.                         }if(count > lifNum[k]){
  46.                                 fuHe = 0;
  47.                                 break;
  48.                         }
  49.                 }
  50.         }
  51.         if(fuHe){
  52.                 printf("经验证,3 - %d 之间所有的整数均符合尼科彻斯定理!\n",num);       
  53.                 printf("\n是否打印所有式子(1/0):");
  54.                 int userChoice;
  55.                 scanf("%d",&userChoice);
  56.                 if(userChoice == 1){
  57.                         for(int p = 0; p < k; p++){
  58.                                 if(shengLue[p]){
  59.                                         printf("%d = %d + %d ... + %d\n", lifNum[p], numList[p][0], numList[p][1], numList[p][2]);
  60.                                 }else{
  61.                                         printf("%d = %d + %d + %d\n", lifNum[p], numList[p][0], numList[p][1], numList[p][2]);
  62.                                 }
  63.                         }
  64.                 }
  65.         }

  66.         return 0;
  67. }
复制代码
最佳答案
2022-9-9 23:57:51
本帖最后由 桃花飞舞 于 2022-9-10 10:18 编辑
jackz007 发表于 2022-9-10 09:54
尼克彻思很简单啊,有那么复杂吗?


他这个代码写的太差,变量用的太多,思路不显而易见,第二用他这种方法来做这个定理验证也不是简单的题, 如果在判断一个数之后
  1.                         if(sum == lifNum[k]){
  2.                                 k++;
  3.                                 break;
  4.                         }
复制代码
把sum清零
  1.                         if(sum == lifNum[k]){
  2.                                 k++;
  3.                                 sum = 0;
  4.                                 break;
  5.                         }
复制代码
,可以避免512的时的问题,但是判断别的数字时候又出现了lifNum[k], numList[k][0], numList[k][1], numList[k][2]变量更新不到正确值得情况,我猜测别的数字也会出现512的现象,只是看不到
Snipaste_2022-09-09_23-53-38.png
Snipaste_2022-09-09_23-56-50.png

最佳答案

查看完整内容

他这个代码写的太差,变量用的太多,思路不显而易见,第二用他这种方法来做这个定理验证也不是简单的题, 如果在判断一个数之后把sum清零,可以避免512的时的问题,但是判断别的数字时候又出现了lifNum[k], numList[k][0], numList[k][1], numList[k][2]变量更新不到正确值得情况,我猜测别的数字也会出现512的现象,只是看不到
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-9-9 23:57:51 | 显示全部楼层    本楼为最佳答案   
本帖最后由 桃花飞舞 于 2022-9-10 10:18 编辑
jackz007 发表于 2022-9-10 09:54
尼克彻思很简单啊,有那么复杂吗?


他这个代码写的太差,变量用的太多,思路不显而易见,第二用他这种方法来做这个定理验证也不是简单的题, 如果在判断一个数之后
  1.                         if(sum == lifNum[k]){
  2.                                 k++;
  3.                                 break;
  4.                         }
复制代码
把sum清零
  1.                         if(sum == lifNum[k]){
  2.                                 k++;
  3.                                 sum = 0;
  4.                                 break;
  5.                         }
复制代码
,可以避免512的时的问题,但是判断别的数字时候又出现了lifNum[k], numList[k][0], numList[k][1], numList[k][2]变量更新不到正确值得情况,我猜测别的数字也会出现512的现象,只是看不到
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-9-10 07:53:41 From FishC Mobile | 显示全部楼层
没时间帮你调试啊
可是,你可以把这个程序copy一份,然后单独对512进行处理,也不要考虑只输出3个数的问题
这样程序会简化不少
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-9-10 09:10:45 | 显示全部楼层
wp231957 发表于 2022-9-10 07:53
没时间帮你调试啊
可是,你可以把这个程序copy一份,然后单独对512进行处理,也不要考虑只输出3个数的问题 ...

赞同1楼说法,其实我也不太了解为什么,因为根本没时间调试查找,我也有事情忙
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-9-10 09:54:48 | 显示全部楼层
本帖最后由 jackz007 于 2022-9-10 09:56 编辑

        尼克彻思很简单啊,有那么复杂吗?
  1. #include <stdio.h>

  2. int nico(int n)
  3. {
  4.         int h , k                                             ;
  5.         h = n * n - n                                         ;
  6.         if(! (h % 2)) h ++                                    ;
  7.         printf("%d = %d" , n * n * n , h)                     ;
  8.         for(k = 1 ; k < n ; k ++) printf(" + %d" , h + 2 * k) ;
  9.         printf("\n")                                          ;
  10.         return h                                              ;
  11. }

  12. int main(void)
  13. {
  14.         int count , j                                                            ;
  15.         char judge                                                               ;
  16.       
  17.         printf("请输入一个整数:")                                               ;
  18.         scanf("%d" , & count)                                                    ;
  19.         printf("经验证 ,3 ~ %d 之间所有的整数均符合尼科彻斯定理!\n\n" , count) ;
  20.         printf("是否打印所有的式子(y/n) :")                                     ;
  21.         fflush(stdin)                                                            ;
  22.         judge = getchar()                                                        ;
  23.         if(judge == 'Y' || judge == 'y') for(j = 3 ; j <= count ; j ++) nico(j)  ;
  24. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-9-10 10:51:43 | 显示全部楼层
jackz007 发表于 2022-9-10 09:54
尼克彻思很简单啊,有那么复杂吗?

我的编程思想还需培养
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-9-10 10:55:49 | 显示全部楼层
桃花飞舞 发表于 2022-9-10 10:08
他这个代码写的太差,变量用的太多,思路不显而易见,第二用他这种方法来做这个定理验证也不是简单的题 ...

确实,64又出问题了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-9-10 11:12:40 | 显示全部楼层
须弥芥子 发表于 2022-9-10 10:55
确实,64又出问题了

这题本来有答案的,你可以按着原题答案的思路来做。如果按照你这个思路,我调试不出来,你再想想别的方法来做,而且这题相当复杂,难度也算进阶了。你一开始数组没有初始化,用了一个for的死循环,而且一维数组,二维数组一起用,也增加了阅读的复杂性。如果不知道结束条件一般建议用while循环。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-9-10 13:11:03 | 显示全部楼层
须弥芥子 发表于 2022-9-10 10:55
确实,64又出问题了

你那种答案的64也是可以这样分解的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-9-10 14:16:09 | 显示全部楼层
练习练习:
  1. #include <stdio.h>

  2. typedef struct {
  3.         int num, n; // num: 整数的平方数, n: 为式子数量
  4.         int start, end; // 式子从 start 开始,并以 +2 方式递增, end 结束
  5. }Nicomachus;

  6. Nicomachus nicomachus(int num) {
  7.         Nicomachus res;
  8.         res.num = num;
  9.         res.start = 1;
  10.         int sum = res.n = 0;
  11.         for (int i = res.start; i <= num; i += 2) {
  12.                 sum += i;
  13.                 res.n++;
  14.                 if (sum > num) {
  15.                         while (sum > num) {
  16.                                 sum -= res.start;
  17.                                 res.start += 2;
  18.                                 res.n--;
  19.                         }
  20.                 }
  21.                 if (sum == num) {
  22.                         res.end = i;
  23.                         break;
  24.                 }
  25.         }
  26.         return res;
  27. }

  28. int main(void) {
  29.         int num = 512;
  30.         Nicomachus res = nicomachus(num);
  31.         printf("%d = %d + ... + %d (共%d个式子)", res.num, res.start, res.end, res.n);
  32.         return 0;
  33. }
复制代码
  1. 512 = 17 + ... + 47 (共16个式子)
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-9-10 14:47:29 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-6-5 15:23

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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