2018-10-10 18:03:03 -04:00
|
|
|
|
---
|
|
|
|
|
id: 5900f3881000cf542c50fe9b
|
2020-12-16 00:37:30 -07:00
|
|
|
|
title: 问题28:对角螺旋数
|
2018-10-10 18:03:03 -04:00
|
|
|
|
challengeType: 5
|
|
|
|
|
videoUrl: ''
|
2021-01-13 03:31:00 +01:00
|
|
|
|
dashedName: problem-28-number-spiral-diagonals
|
2018-10-10 18:03:03 -04:00
|
|
|
|
---
|
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
# --description--
|
|
|
|
|
|
2020-02-18 01:40:55 +09:00
|
|
|
|
从数字1开始,沿顺时针方向向右移动,形成5 x 5螺旋,如下所示:
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
2020-02-18 01:40:55 +09:00
|
|
|
|
21 22 23 24 25
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
2020-02-18 01:40:55 +09:00
|
|
|
|
20 7 8 9 10
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
2020-02-18 01:40:55 +09:00
|
|
|
|
19 6 1 2 11
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
2020-02-18 01:40:55 +09:00
|
|
|
|
18 5 4 3 12
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
2020-02-18 01:40:55 +09:00
|
|
|
|
17 16 15 14 13
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
可以验证对角线上的数字之和为101。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
以相同方式形成的n×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
|
|
|
|
`spiralDiagonals(101)`应该返回692101。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
|
|
|
|
```js
|
2020-12-16 00:37:30 -07:00
|
|
|
|
assert(spiralDiagonals(101) == 692101);
|
2018-10-10 18:03:03 -04:00
|
|
|
|
```
|
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
`spiralDiagonals(101)`应该返回18591725。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
```js
|
|
|
|
|
assert(spiralDiagonals(303) == 18591725);
|
|
|
|
|
```
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
`spiralDiagonals(101)`应该返回85986601。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
```js
|
|
|
|
|
assert(spiralDiagonals(505) == 85986601);
|
|
|
|
|
```
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
`spiralDiagonals(101)`应该返回669171001。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
|
|
|
|
```js
|
2020-12-16 00:37:30 -07:00
|
|
|
|
assert(spiralDiagonals(1001) == 669171001);
|
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 spiralDiagonals(n) {
|
|
|
|
|
|
|
|
|
|
return n;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
spiralDiagonals(1001);
|
|
|
|
|
```
|
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
# --solutions--
|
|
|
|
|
|
2021-01-13 03:31:00 +01:00
|
|
|
|
```js
|
|
|
|
|
const spiralDiagonals = (n) => {
|
|
|
|
|
const Sn2 = (n) => {
|
|
|
|
|
return n*(n+1)*(2*n+1)/6;
|
|
|
|
|
};
|
|
|
|
|
const Sn = (n) => {
|
|
|
|
|
return n*(n+1)/2;
|
|
|
|
|
};
|
|
|
|
|
let sum = (Sn2(n-1) + Sn(n-1) + n-1) + (Math.floor(n/2) + Sn2(n));
|
|
|
|
|
return sum;
|
|
|
|
|
};
|
|
|
|
|
```
|