PTA 520 钻石争霸赛 2021 大勾股定理 (15 分)【数学】

本文介绍了大勾股定理的推广,即对于任何正整数n存在一组连续正整数,满足前n+1个数的平方和等于后n个数的平方和。通过数学推导,得出了一元二次方程并求解,得到通解公式。随后给出了C++代码实现,展示了如何根据给定的n找到满足条件的数列。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

大勾股定理是勾股定理的推广:对任何正整数 n n n 存在 2 n + 1 2n+1 2n+1 个连续正整数,满足前 n + 1 n+1 n+1 个数的平方和等于后 n n n 个数的平方和。例如对于 n = 1 n=1 n=1 3 2 ​ ​ + 4 2 ​ ​ = 5 ​ 2 3^2​​+4^2​​=5^​2 32+42=52 ​​; n = 2 n=2 n=2 1 0 2 ​ ​ + 1 1 2 ​ ​ + 1 2 2 ​ ​ = 1 3 2 ​ ​ + 1 4 2 10^2​​+11^2​​+12^2​​=13^2​​+14^2 102+112+122=132+142​​ 等。给定 n n n ,本题就请你找出对应的解。

输入格式:
输入在一行中给出正整数 n n n ≤ 1 0 4 ≤10^4 104​​)。

输出格式:
分两行输出满足大勾股定理的解,格式如下:

a[0]^2 + a[1]^2 + ... + a[n]^2 =
a[n+1]^2 + ... + a[2n]^2

其中解的数列 a[0] ... a[2n] 按递增序输出。注意行首尾不得有多余空格。

输入样例:

3

输出样例:

21^2 + 22^2 + 23^2 + 24^2 =
25^2 + 26^2 + 27^2

解法 数学

乍一看本题就有点来势汹汹,如果暴力求前 n + 1 n + 1 n+1 个数的平方和,然后暴力求后 n + 1 n+1 n+1 个数的平方和……复杂度难以想象。

事实上,本题很简单,我们设 A = a [ 0 ]   ( A > 0 ) A = a[0]\ ( A > 0) A=a[0] (A>0) ,大勾股定理可以表述为:对任何正整数 n n n 存在一组 2 n + 1 2n+1 2n+1 个从 A A A 开始的连续正整数,满足前 n + 1 n +1 n+1 个正整数的平方和等于后 n n n 个数的平方和,即为:
A 2 + ( A + 1 ) 2 + . . . + ( A + n ) 2 = ( A + n + 1 ) 2 + ( A + n + 2 ) 2 + . . + ( A + 2 n ) 2 A^2 + (A+1)^2 + ... + (A+n)^2 \\= (A+n+1)^2 + (A+n+2)^2 + .. + (A+2n)^2 A2+(A+1)2+...+(A+n)2=(A+n+1)2+(A+n+2)2+..+(A+2n)2

前后抵消同类项(前 n + 1 n+1 n+1 项的后 n n n 项与后式抵消),得到:
A 2 = n 2 + 2 ∗ ( A + 1 ) ∗ n + n 2 + 2 ∗ ( A + 2 ) ∗ n + . . . + n 2 + 2 ∗ ( A + n ) ∗ n A^2 \\= n^2+2*(A+1)*n + n^2+2*(A+2)*n + ... + n^2+2*(A+n)*n A2=n2+2(A+1)n+n2+2(A+2)n+...+n2+2(A+n)n

继续推导:
A 2 = n 3 + 2 n ( A + 1 + A + 2 + . . . + A + n ) A^2 = n^3 + 2n(A+1+A+2+...+A+n) A2=n3+2n(A+1+A+2+...+A+n)

接着运用等差数列求和的公式,计算得到:
A 2 = n 3 + n 2 ( 2 A + n + 1 ) A^2 = n^3 + n^2 (2A+n+1) A2=n3+n2(2A+n+1)

接下来就很简单了,将所有项都移动到左侧,得到一个关于 A A A 的一元二次方程:
A 2 − 2 n 2 A − 2 n 3 − n 2 = 0 A^2 - 2n^2A - 2n^3 - n^2 =0 A22n2A2n3n2=0

运用对应的求根公式:
x = − b   ±   b 2 − 4 a c 2 a x = \frac{-b\ \pm \ \sqrt{b^2 - 4ac}}{2a} x=2ab ± b24ac

由于 A > 0 A > 0 A>0 ,取正根,所以有: A = 2 n 2   +   4 n 4 + 4 n 2 + 8 n 3 2 = n 2 + n 4 + n 2 + 2 n 3 = n 2 + n n 2 + 2 n + 1 = 2 n 2 + n A = \frac{2n^2\ + \ \sqrt{4n^4 + 4n^2 + 8n^3}}{2} = n^2 + \sqrt{n^4+n^2+2n^3} \\= n^2+n\sqrt{n^2+2n+1} = 2n^2 +n A=22n2 + 4n4+4n2+8n3 =n2+n4+n2+2n3 =n2+nn2+2n+1 =2n2+n

现在可以写出代码了。由于代码是比赛时随手写的,所以并不是很简洁,求 A A A 的公式没有化到最简单,最后的两个用于输出的 for 循环可以合并:

#include <bits/stdc++.h>
using namespace std; 
long long n;
int main() {
    scanf("%lld", &n);
    long long n2 = n * n, n3 = n2 * n; 
    long long A = (n2 * 2 + sqrt((n2 * 2) * (n2 * 2) + 4 * (2 * n3 + n2))) / 2;
    for (int i = 0; i <= n; ++i) {
        if (i == 0) printf("%d^2", A + i);
        else printf(" + %d^2", A + i);
    }
    printf(" =\n");
    for (int i = n + 1; i <= 2 * n; ++i) {
        if (i == n + 1) printf("%d^2", A + i);
        else printf(" + %d^2", A + i);
    }
    return 0;
}

在这里插入图片描述

经过网络搜索,以下是关于PTA 520钻石及相关产品信息的整理: --- ### 关于PTA 520钻石的相关背景 PTA通常指精对苯二甲酸(Pure Terephthalic Acid),是一种重要的化工原料。而“520”可能是指特日期(例如5月20日)或者某种特殊型号的产品名称。“钻石”则可能是品牌名或营销概念的一部。结合这些关键词,“PTA 520钻石”可能涉及纪念品、收藏品或其他制化礼品。 --- ### 可能的产品类别与特点 #### 1. 制类珠宝产品 一些商家会推出以“520”为主题的钻戒、吊坠等珠宝产品,寓意“我爱你”。这类产品可能会采用高品质钻石,并搭配个性化设计服务。 - **材料**:天然钻石、K金、铂金等贵金属材质。 - **工艺**:3D硬金技术、微镶工艺等现代加工方式。 - **购买渠道**:知名珠宝品牌的线下门店或电商平台旗舰店(如周福、老凤祥)。 #### 2. 化工行业联名款礼盒 由于PTA属于化工领域的重要原材料,在某些企业活动中,可能会推出带有“520”主题的限量版礼盒作为促销手段或员工福利。此类礼盒可能包括小型饰品模型以及相关宣传资料。 #### 3. 投资级钻石证书配套产品 对于关注投资价值的人群来说,市场上存在附带国际权威机构认证书的投资级别裸钻。这种类型的钻石适合长期保值增值需求。具体参数如下所示: | 参数 | 描述 | |------------|----------------------------------------------------------------------| | 净度 (Clarity) | VVS1 / VS2 | | 切工 (Cut) | Excellent | | 色泽 (Color) | D-E | | 克拉数 (Carat Weight)| ≥1克拉 | --- ### 如何选择合适的PTA 520钻石产品? 根据个人用途不同可以选择相应款式:如果是用于表白求婚,则建议挑选经典简约风格;若是为了资产配置考虑,则需注重GIA/HRD/AIG等第三方检测报告的真实性与完整性。 --- ### 注意事项 消费者在选购过程中应注意辨别真伪以防上当受骗。正规途径获取的商品不仅质量更有保障而且售后服务也相对完善。 ---
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

memcpy0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值