2018-10-10 18:03:03 -04:00
|
|
|
|
---
|
|
|
|
|
id: 594810f028c0303b75339acb
|
2021-07-15 13:04:11 +05:30
|
|
|
|
title: 100 门
|
2018-10-10 18:03:03 -04:00
|
|
|
|
challengeType: 5
|
2021-02-06 04:42:36 +00:00
|
|
|
|
forumTopicId: 302217
|
2021-01-13 03:31:00 +01:00
|
|
|
|
dashedName: 100-doors
|
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
|
|
|
|
|
2021-09-21 08:09:14 -07:00
|
|
|
|
连续 100 个门都是最初关闭的。 你在门前通行了 100 次。 第一次通行时,访问每扇门,并“切换”门(如果门是关闭的,就打开它;如果门是打开的,就关闭它)。 第二次,只访问每个第二扇门(即门 #2,#4,#6,...)并切换它们。 第三次,每三个门访问一次(即门 #3,#6,#9,...)等,直到你只访问第 100 个门。
|
2021-02-06 04:42:36 +00:00
|
|
|
|
|
|
|
|
|
# --instructions--
|
|
|
|
|
|
2021-09-21 08:09:14 -07:00
|
|
|
|
实现一个函数,以确定最后一次通过后门的状态。 以数组形式返回最终结果,数组中只包含打开的门的门号。
|
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
|
|
|
|
|
2021-09-21 08:09:14 -07:00
|
|
|
|
`getFinalOpenedDoors` 应该是一个函数。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
|
|
|
|
```js
|
2020-12-16 00:37:30 -07:00
|
|
|
|
assert(typeof getFinalOpenedDoors === 'function');
|
2018-10-10 18:03:03 -04:00
|
|
|
|
```
|
|
|
|
|
|
2021-09-21 08:09:14 -07:00
|
|
|
|
`getFinalOpenedDoors` 应该返回一个数组。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
|
|
|
|
```js
|
2020-12-16 00:37:30 -07:00
|
|
|
|
assert(Array.isArray(getFinalOpenedDoors(100)));
|
2018-10-10 18:03:03 -04:00
|
|
|
|
```
|
|
|
|
|
|
2021-09-21 08:09:14 -07:00
|
|
|
|
`getFinalOpenedDoors` 应该产生正确的结果。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
|
|
|
|
```js
|
2020-12-16 00:37:30 -07:00
|
|
|
|
assert.deepEqual(getFinalOpenedDoors(100), solution);
|
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--
|
|
|
|
|
|
|
|
|
|
## --after-user-code--
|
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
const solution = [1, 4, 9, 16, 25, 36, 49, 64, 81, 100];
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## --seed-contents--
|
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
function getFinalOpenedDoors(numDoors) {
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
# --solutions--
|
|
|
|
|
|
2021-01-13 03:31:00 +01:00
|
|
|
|
```js
|
|
|
|
|
function getFinalOpenedDoors(numDoors) {
|
|
|
|
|
// this is the final pattern (always squares).
|
|
|
|
|
// thus, the most efficient solution simply returns an array of squares up to numDoors).
|
|
|
|
|
const finalState = [];
|
|
|
|
|
let i = 1;
|
|
|
|
|
while (Math.pow(i, 2) <= numDoors) {
|
|
|
|
|
finalState.push(Math.pow(i, 2));
|
|
|
|
|
i++;
|
|
|
|
|
}
|
|
|
|
|
return finalState;
|
|
|
|
|
}
|
|
|
|
|
```
|