欧拉计划第6题:Sum square difference(和的平方 平方的和)

欧拉计划简介,本系列希望以通俗易懂的语言、简洁的代码,带大家体会数学与编程结合的魅力。

Problem 6:Sum square difference

标签:和的平方、平方的和

原文:The sum of the squares of the first ten natural numbers is,

1 2 + 2 2 + ... + 1 0 2 = 385 1^2+2^2+\ldots +10^2=385 12+22+...+102=385

The square of the sum of the first ten natural numbers is,

( 1 + 2 + ... + 10 ) 2 = 5 5 2 = 3025 (1+2+\ldots+10)^2 = 55^2 = 3025 (1+2+...+10)2=552=3025

Hence the difference between the sum of the squares of the first ten natural numbers and the square of the sum is 3025 − 385 = 2640 3025 − 385 = 2640 3025−385=2640.

Find the difference between the sum of the squares of the first one hundred natural numbers and the square of the sum.

翻译 :前十个自然数的 平方的和

1 2 + 2 2 + ... + 1 0 2 = 385 1^2+2^2+\ldots +10^2=385 12+22+...+102=385

前十个自然数的 和的平方

( 1 + 2 + ... + 10 ) 2 = 5 5 2 = 3025 (1+2+\ldots+10)^2 = 55^2 = 3025 (1+2+...+10)2=552=3025

因此,前十个自然数 和的平方平方的和 之差是 3025 − 385 = 2640 3025 − 385 = 2640 3025−385=2640。

求前一百个自然数 和的平方平方的和 之差。

枚举法题解:循环枚举一下。

枚举法代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int main() {
    int sum1 = 0, sum2 = 0;
    for (int i = 1; i <= 100; i++) {
        sum1 += i;
        sum2 += i * i;
    }
    // 和的平方、平方的和
    cout << sum1 * sum1 - sum2 << endl;
    return 0;
}

数学题解 :自然数的 和的平方 通项公式为 X = ( n ( n + 1 ) 2 ) 2 \large X=(\frac{n(n+1)}{2})^2 X=(2n(n+1))2

自然数的 平方的和 通项公式为 Y = n ( n + 1 ) ( 2 n + 1 ) 6 \large Y=\frac{n(n+1)(2n+1)}{6} Y=6n(n+1)(2n+1)

和的平方平方的和 差值公式为: X − Y = ( n ( n + 1 ) 2 ) 2 − n ( n + 1 ) ( 2 n + 1 ) 6 = n ( n − 1 ) ( n + 1 ) ( 3 n + 2 ) 12 X-Y=(\frac{n(n+1)}{2})^2-\frac{n(n+1)(2n+1)}{6}=\frac{n(n-1)(n+1)(3n+2)}{12} X−Y=(2n(n+1))2−6n(n+1)(2n+1)=12n(n−1)(n+1)(3n+2)

数学代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int main() {
    int n = 100;
    cout << n * (n-1) * (n+1) * (3*n+2) / 12;
    return 0;
}

"Project Euler exists to encourage, challenge, and develop the skills and enjoyment of anyone with an interest in the fascinating world of mathematics."

"欧拉计划的存在,是为了每个对数学感兴趣的人,鼓励他们,挑战他们,并最终培养他们的能力与乐趣。"

相关推荐
DKPT1 分钟前
数据结构之快速排序、堆排序概念与实现举例
java·数据结构·算法
Hiweir ·15 分钟前
机器翻译之创建Seq2Seq的编码器、解码器
人工智能·pytorch·python·rnn·深度学习·算法·lstm
Element_南笙17 分钟前
数据结构_1、基本概念
数据结构·人工智能
不染_是非25 分钟前
Django学习实战篇六(适合略有基础的新手小白学习)(从0开发项目)
后端·python·学习·django
qq_18735263427 分钟前
马踏棋盘c++
开发语言·c++·马踏棋盘c++
star数模27 分钟前
2024“华为杯”中国研究生数学建模竞赛(E题)深度剖析_数学建模完整过程+详细思路+代码全解析
python·算法·数学建模
Tak1Na30 分钟前
2024.9.19
算法
Midsummer啦啦啦37 分钟前
NumPy库学习之argmax函数
学习·numpy
Mero技术博客40 分钟前
第二十节:学习Redis缓存数据库实现增删改查(自学Spring boot 3.x的第五天)
数据库·学习·缓存
熙曦Sakura43 分钟前
【数据结构】队列
数据结构