鱼C论坛

 找回密码
 立即注册
查看: 1740|回复: 5

[已解决]C程序输出错误,原因不明?

[复制链接]
发表于 2022-1-9 20:47:34 | 显示全部楼层 |阅读模式
3鱼币
带你学C带你飞第一季第21指针课后习题的最后一个题目:https://fishc.com.cn/forum.php?m ... peid%26typeid%3D570

改进上一题的代码,用户输入一个表示范围的最大值 count,程序将测试 3 ~ count 所有的整数是否都符合尼科彻斯定理。
附加要求:有些用户可能不希望看到打印一丢丢式子,所以是否打印应该让用户确定(提示 -> 用二维数组先保存结果)。
我测试了小甲鱼的代码,输出结果如下图所示:

测试输入3

测试输入3

测试输入5

测试输入5

测试输入10

测试输入10


输出结果会出现一个奇怪的数字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[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;
}
最佳答案
2022-1-9 20:47:35
cben 发表于 2022-1-9 22:08
程序有多处报错,无法正常运行

我用的是vs,主要是告诉你如果动态数组count不加一会发生越界

最佳答案

查看完整内容

我用的是vs,主要是告诉你如果动态数组count不加一会发生越界
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-1-9 20:47:35 | 显示全部楼层    本楼为最佳答案   
cben 发表于 2022-1-9 22:08
程序有多处报错,无法正常运行

我用的是vs,主要是告诉你如果动态数组count不加一会发生越界
无标题.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-1-9 21:20:08 | 显示全部楼层
我用dev没有问题

                               
登录/注册后可看大图
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2022-1-9 21:40:15 | 显示全部楼层
  1. #include <stdio.h>


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

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

  9.         int (*array)[4]=new int[count+1][4];//////////////////////////////////数组的count得加1,要不然后面 for (n = 3; n <= count; n++)都会越界
  10.         // 变长数组无法再定义是初始化,只能手动了...
  11.         for (n = 3; n <= count; n++)
  12.         {
  13.                // 初始化第一列,因为后边用于验证
  14.                array[n][0] = 0;
  15.         }

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

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

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

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

  64.         if (answer == 'y')
  65.         {
  66.                 // 打印
  67.                 for (n = 3; n <= count; n++)
  68.                 {
  69.                         if (array[n][3] - array[n][1] > 4)
  70.                         {
  71.                                 printf("%d^3 == %d == %d + %d +... + %d\n", n, array[n][0], array[n][1], array[n][2], array[n][3]);
  72.                         }
  73.                         else
  74.                         {
  75.                                 printf("%d^3 == %d == %d + %d + %d\n", n, array[n][0], array[n][1], array[n][2], array[n][3]);
  76.                         }
  77.                 }
  78.         }
  79.                 delete[] array;
  80.         return 0;
  81. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-1-9 22:08:23 | 显示全部楼层

程序有多处报错,无法正常运行
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-1-9 22:36:19 | 显示全部楼层
jhq999 发表于 2022-1-9 22:17
我用的是vs,主要是告诉你如果动态数组count不加一会发生越界

您可以在codeblocks上测试吗?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-25 04:46

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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