鱼C论坛

 找回密码
 立即注册
查看: 1508|回复: 0

[技术交流] 尼科彻斯定理

[复制链接]
发表于 2020-5-18 13:11:19 | 显示全部楼层 |阅读模式

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

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

x
#include <stdio.h>
#include <math.h>

#define NUM 128

int main()
{
        int num[NUM][NUM];
        int cube1, cube2, right, count;
        int i, j, k; 
        char q;
        
        printf("请输入一个整数:");
        scanf("%d", &count);
        
        cube1 = count * count * count;
        right = count * (count * (count - 1) + 1) + count * (count -1);
        
        if (cube1 == right) 
        {
                printf("经验证,3 ~ %d之间的所有整数均符合尼科彻斯定理!\n\n", count);
        }
        
        getchar();
        
        printf("是否打印所有式子(y/n):");
        scanf("%c", &q);
        
        if (q == 'y')
        {
                for (i = 0; i < count - 2; i++) //3~count之间所有整数
                        {
                                k = i + 3;
                                cube2 = k * k * k;
                                printf("%d^%d == %d == ", k, k, cube2);
                                for (j = 0; j < 3 + i && j < count; j++)                
                                {
                                        num[i][j] = k * (k - 1) + 1 + 2 * j;
                                        printf(j? "+ %d " : "%d ", num[i][j]);
                                }
                                printf("\n");
                        }                
        }
        
        else
        {
                printf("\n");
        }
                
        return 0;
}
 


我还以为老师的答案错了,原来老师的尼科彻斯定理跟百度的不一样,晕!!!
#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;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-1-14 00:41

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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