2018-10-10 18:03:03 -04:00
|
|
|
|
---
|
|
|
|
|
id: 5900f3721000cf542c50fe85
|
2020-12-16 00:37:30 -07:00
|
|
|
|
title: 问题6:求和方差
|
2018-10-10 18:03:03 -04:00
|
|
|
|
challengeType: 5
|
|
|
|
|
videoUrl: ''
|
2021-01-13 03:31:00 +01:00
|
|
|
|
dashedName: problem-6-sum-square-difference
|
2018-10-10 18:03:03 -04:00
|
|
|
|
---
|
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
# --description--
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
前十个自然数的平方和是,
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
1
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
<sup>2</sup>
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
- 2
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
<sup>2</sup>
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
- ... + 10
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
<sup>2</sup>
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
= 385
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
前十个自然数之和的平方是,
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
(1 + 2 + ... + 10)
|
|
|
|
|
|
|
|
|
|
<sup>2</sup>
|
|
|
|
|
|
|
|
|
|
= 55
|
|
|
|
|
|
|
|
|
|
<sup>2</sup>
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
= 3025
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
因此,前十个自然数的平方和与和的平方之间的差值为3025 - 385 = 2640.求出前`n`自然数的平方和与总和的平方之间的差值。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
# --hints--
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
`sumSquareDifference(10)`应该返回2640。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
```js
|
|
|
|
|
assert.strictEqual(sumSquareDifference(10), 2640);
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
`sumSquareDifference(20)`应该返回41230。
|
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
assert.strictEqual(sumSquareDifference(20), 41230);
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
`sumSquareDifference(100)`应该返回25164150。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
|
|
|
|
```js
|
2020-12-16 00:37:30 -07:00
|
|
|
|
assert.strictEqual(sumSquareDifference(100), 25164150);
|
2018-10-10 18:03:03 -04:00
|
|
|
|
```
|
2020-08-13 17:24:35 +02:00
|
|
|
|
|
2021-01-13 03:31:00 +01:00
|
|
|
|
# --seed--
|
|
|
|
|
|
|
|
|
|
## --seed-contents--
|
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
function sumSquareDifference(n) {
|
|
|
|
|
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
sumSquareDifference(100);
|
|
|
|
|
```
|
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
# --solutions--
|
|
|
|
|
|
2021-01-13 03:31:00 +01:00
|
|
|
|
```js
|
|
|
|
|
const sumSquareDifference = (number)=>{
|
|
|
|
|
let squareOfSum = Math.pow(sumOfArithmeticSeries(1,1,number),2);
|
|
|
|
|
let sumOfSquare = sumOfSquareOfNumbers(number);
|
|
|
|
|
return squareOfSum - sumOfSquare;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function sumOfArithmeticSeries(a,d,n){
|
|
|
|
|
return (n/2)*(2*a+(n-1)*d);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function sumOfSquareOfNumbers(n){
|
|
|
|
|
return (n*(n+1)*(2*n+1))/6;
|
|
|
|
|
}
|
|
|
|
|
```
|