鱼C论坛

 找回密码
 立即注册
查看: 1423|回复: 13

[已解决]求大佬解惑

[复制链接]
发表于 2021-8-14 08:52:25 | 显示全部楼层 |阅读模式
15鱼币
课后作业S1E21的动动手2的这段代码,在vscode编译时,int array[count][4],无论n是多少,编译出来array[count][3]都是错的,如果改成int array[count][5]就可以了,但是在Dev C++用array[count][4]编译却没问题,是不是我的vscode哪里设置错了,求大佬解答!!!
  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");
  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. }
复制代码

最佳答案
2021-8-14 08:52:26
wxm23333 发表于 2021-8-14 11:47
设count=10,用小于结果就没有最后的10的3次方,用小于等于还是原来的问题,10的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.     int array[count + 1][4];
  12.     // 变长数组无法再定义是初始化,只能手动了...
  13.     for (n = 3; n <= count; n++)
  14.     {
  15.         // 初始化第一列,因为后边用于验证
  16.         array[n][0] = 0;
  17.     }

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

  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.     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.     return 0;
  80. }
复制代码
1.jpg
2.jpg

最佳答案

查看完整内容

编程是很灵活的
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-8-14 08:52:26 | 显示全部楼层    本楼为最佳答案   
wxm23333 发表于 2021-8-14 11:47
设count=10,用小于结果就没有最后的10的3次方,用小于等于还是原来的问题,10的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.     int array[count + 1][4];
  12.     // 变长数组无法再定义是初始化,只能手动了...
  13.     for (n = 3; n <= count; n++)
  14.     {
  15.         // 初始化第一列,因为后边用于验证
  16.         array[n][0] = 0;
  17.     }

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

  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.     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.     return 0;
  80. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-8-14 10:43:25 | 显示全部楼层
  1. int array[count][4];
  2. for (n = 3; n <= count; n++)
  3. array[n][0] = 0;
复制代码


下面这两个程序哪一个是对的?
  1. #include <stdio.h>

  2. int main(void) {
  3.     int array[5];
  4.     for(size_t i = 0; i <= 5; ++i)
  5.         array[i] = 0;
  6.     return 0;
  7. }
复制代码

  1. #include <stdio.h>

  2. int main(void) {
  3.     int array[5];
  4.     for(size_t i = 0; i < 5; ++i)
  5.         array[i] = 0;
  6.     return 0;
  7. }
复制代码


还有,把题目贴出来
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-8-14 11:33:14 | 显示全部楼层
人造人 发表于 2021-8-14 10:43
下面这两个程序哪一个是对的?

题目
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-8-14 11:36:16 | 显示全部楼层
人造人 发表于 2021-8-14 10:43
下面这两个程序哪一个是对的?

是将这段两段代码分别在原代码里面替换吗
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-8-14 11:36:18 | 显示全部楼层

这样把题目贴出来更好,直接就能看到题目
1.png
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-8-14 11:38:18 | 显示全部楼层
  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.     for (n = 3; n < count; n++)
  14.     {
  15.         // 初始化第一列,因为后边用于验证
  16.         array[n][0] = 0;
  17.     }

  18.     //for (n = 3; n <= count; n++)
  19.     for (n = 3; n < count; n++)
  20.     {
  21.         cubed = n * n * n;
  22.         for (i = 1; i < cubed; i += 2)
  23.         {
  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] = i + 2;
  32.                     array[n][3] = j;

  33.                     goto FINDIT;
  34.                 }

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

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

  45.     // 检查
  46.     //for (n = 3; n <= count; n++)
  47.     for (n = 3; n < count; n++)
  48.     {
  49.         if (array[n][0] == 0)
  50.         {
  51.             result = false;
  52.             break;
  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");
  65.     }

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

  82.     return 0;
  83. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-8-14 11:38:55 | 显示全部楼层
wxm23333 发表于 2021-8-14 11:36
是将这段两段代码分别在原代码里面替换吗

是小于还是小于等于?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-8-14 11:47:59 | 显示全部楼层
人造人 发表于 2021-8-14 11:38
是小于还是小于等于?

设count=10,用小于结果就没有最后的10的3次方,用小于等于还是原来的问题,10的3次方的等式的最后一个数字是错的
捕获.PNG
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-8-14 12:40:48 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-8-14 12:56:53 | 显示全部楼层
  1. #include "stdafx.h"

  2. #include <stdio.h>
  3. //#include <math.h>
  4. void main ()
  5. {
  6.         int i=0,num=0,tmpval=0,sum=0;
  7.         char ch[32]={0};
  8.         gets_s(ch);
  9.         while (ch[i])
  10.         {
  11.                 num*=10;
  12.                 num+=ch[i]-48;
  13.                 i++;
  14.         }
  15.         tmpval=num*num-num+1;
  16.         sum=tmpval;
  17.         printf("%d",tmpval);
  18.         for (i = 1; i < num; i++)
  19.         {
  20.                 printf(" + %d",tmpval+i*2);
  21.                 sum+=tmpval+i*2;

  22.         }
  23.         printf(" = %d",sum);
  24.         getchar();
  25. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-8-14 15:38:11 | 显示全部楼层

我在想,设定的数组是count行4列的,实际上是从第0行到第count-1行的。最后要求打印时n等于第count行,已经超出了数组设定的边界,然后在你这设定的数组是count+1行的,实际是从第0行到第count行的,最后打印时没有超出边界,所以显示正常。
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-8-14 17:52:00 | 显示全部楼层
wxm23333 发表于 2021-8-14 15:38
我在想,设定的数组是count行4列的,实际上是从第0行到第count-1行的。最后要求打印时n等于第count行,已 ...

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-8-14 18:55:21 | 显示全部楼层

感谢大佬指导
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-4-26 22:18

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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