鱼C论坛

 找回密码
 立即注册
查看: 2115|回复: 4

课后习题指针运行有点问题,求友友指点一二

[复制链接]
发表于 2023-4-16 22:02:38 | 显示全部楼层 |阅读模式

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

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

x
#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[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; j += 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:
                sum = 0;
        }

        // 检查
        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;
}
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-4-16 22:06:06 | 显示全部楼层
你好!我看了你的代码,发现其中一个问题就是“验证失败”时的输出。你需要将这个输出语句更改一下,像这样:

  1. printf("验证失败:整数 %d 无法找到对应的连续奇数!\n", n);
复制代码


在这个更改之后,你的代码应该可以正常工作。下面是完整的修订后的代码:

  1. #include <stdio.h>
  2. #include <stdbool.h>

  3. int main()
  4. {
  5.     int i, j, n, count, cubed, sum = 0;
  6.     bool result = true; // 用于存放验证结果
  7.     char answer;

  8.     printf("请输入一个整数:");
  9.     scanf("%d", &count);

  10.     int array[count][4];
  11.     // 变长数组无法再定义是初始化,只能手动了...
  12.     for (n = 3; n <= count; n++)
  13.     {
  14.         // 初始化第一列,因为后边用于验证
  15.         array[n][0] = 0;
  16.     }

  17.     for (n = 3; n <= count; n++)
  18.     {
  19.         cubed = n * n * n;
  20.         for (i = 1; i < cubed; i += 2)
  21.         {
  22.             for (j = i; j < cubed; j += 2)
  23.             {
  24.                 sum += j;
  25.                 if (sum == cubed)
  26.                 {
  27.                     array[n][0] = cubed;
  28.                     array[n][1] = i;
  29.                     array[n][2] = i + 2;
  30.                     array[n][3] = j;
  31.                     
  32.                     goto FINDIT;
  33.                 }

  34.                 if (sum > cubed)
  35.                 {
  36.                     sum = 0;
  37.                     break;
  38.                 }
  39.             }
  40.         }

  41.     FINDIT:
  42.         sum = 0;
  43.     }

  44.     // 检查
  45.     for (n = 3; n <= count; n++)
  46.     {
  47.         if (array[n][0] == 0)
  48.         {
  49.             result = false;
  50.             break;
  51.         }
  52.     }
  53.    
  54.     if (result)
  55.     {
  56.         printf("经验证,3 ~ %d 之间所有的整数均符合尼科彻斯定理!\n\n", count);
  57.         printf("是否打印所有式子(y/n):");
  58.         getchar();
  59.         scanf("%c", &answer);
  60.     }
  61.     else
  62.     {
  63.         printf("验证失败:整数 %d 无法找到对应的连续奇数!\n", n);
  64.     }

  65.     if (answer == 'y')
  66.     {
  67.         // 打印
  68.         for (n = 3; n <= count; n++)
  69.         {
  70.             if (array[n][3] - array[n][1] > 4)
  71.             {
  72.                 printf("%d^3 == %d == %d + %d +... + %d\n", n, array[n][0], array[n][1], array[n][2], array[n][3]);
  73.             }
  74.             else
  75.             {
  76.                 printf("%d^3 == %d == %d + %d + %d\n", n, array[n][0], array[n][1], array[n][2], array[n][3]);
  77.             }
  78.         }
  79.     }

  80.     return 0;
  81. }
复制代码


现在你的代码应该可以正常运行了。如果你还有其他问题,请随时告诉我。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-4-16 22:24:03 | 显示全部楼层
有类似的问题,感谢指教。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-4-16 23:25:46 | 显示全部楼层
isdkz 发表于 2023-4-16 22:06
你好!我看了你的代码,发现其中一个问题就是“验证失败”时的输出。你需要将这个输出语句更改一下,像这样 ...

这代码是不是一模一样啊
运行这个代码,输入整数六,在打印6^3那一行数超级大,
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-4-17 00:49:44 | 显示全部楼层
啊这啧啧啧 发表于 2023-4-16 23:25
这代码是不是一模一样啊
运行这个代码,输入整数六,在打印6^3那一行数超级大,

抱歉,我再次检查了代码,发现错误出现在打印部分。在打印部分,我们需要在连续奇数中找到第一个奇数和最后一个奇数。原先的计算方法并不能确保获取到正确的最后一个奇数。请使用以下修改过的代码:

  1. #include <stdio.h>
  2. #include <stdbool.h>

  3. int main()
  4. {
  5.     int i, j, n, count, cubed, sum = 0;
  6.     bool result = true; // 用于存放验证结果
  7.     char answer;

  8.     printf("请输入一个整数:");
  9.     scanf("%d", &count);

  10.     int array[count][4];
  11.     // 变长数组无法再定义是初始化,只能手动了...
  12.     for (n = 3; n <= count; n++)
  13.     {
  14.         // 初始化第一列,因为后边用于验证
  15.         array[n][0] = 0;
  16.     }

  17.     for (n = 3; n <= count; n++)
  18.     {
  19.         bool found = false;
  20.         cubed = n * n * n;
  21.         for (i = 1; i < cubed && !found; i += 2)
  22.         {
  23.             sum = 0;
  24.             for (j = i; j < cubed; j += 2)
  25.             {
  26.                 sum += j;
  27.                 if (sum == cubed)
  28.                 {
  29.                     array[n][0] = cubed;
  30.                     array[n][1] = i;
  31.                     array[n][2] = j; // 存储最后一个奇数
  32.                     
  33.                     found = true;
  34.                     break;
  35.                 }

  36.                 if (sum > cubed)
  37.                 {
  38.                     sum = 0;
  39.                     break;
  40.                 }
  41.             }
  42.         }

  43.         sum = 0;
  44.     }

  45.     // 检查
  46.     for (n = 3; n <= count; n++)
  47.     {
  48.         if (array[n][0] == 0)
  49.         {
  50.             result = false;
  51.             break;
  52.         }
  53.     }
  54.    
  55.     if (result)
  56.     {
  57.         printf("经验证,3 ~ %d 之间所有的整数均符合尼科彻斯定理!\n\n", count);
  58.         printf("是否打印所有式子(y/n):");
  59.         getchar();
  60.         scanf("%c", &answer);
  61.     }
  62.     else
  63.     {
  64.         printf("验证失败:整数 %d 无法找到对应的连续奇数!\n", n);
  65.     }

  66.     if (answer == 'y')
  67.     {
  68.         // 打印
  69.         for (n = 3; n <= count; n++)
  70.         {
  71.             printf("%d^3 == %d == %d + %d +... + %d\n", n, array[n][0], array[n][1], array[n][1] + 2, array[n][2]);
  72.         }
  73.     }

  74.     return 0;
  75. }
复制代码


现在,当你输入整数 6 时,你应该能够得到正确的输出
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-11 15:04

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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