2018-10-10 18:03:03 -04:00
|
|
|
|
---
|
|
|
|
|
id: a24c1a4622e3c05097f71d67
|
2021-01-12 08:18:51 -08:00
|
|
|
|
title: 找出元素在排序后数组中的索引
|
2018-10-10 18:03:03 -04:00
|
|
|
|
challengeType: 5
|
2021-01-12 08:18:51 -08:00
|
|
|
|
forumTopicId: 16094
|
2021-01-13 03:31:00 +01:00
|
|
|
|
dashedName: where-do-i-belong
|
2018-10-10 18:03:03 -04:00
|
|
|
|
---
|
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
# --description--
|
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
第一个参数的数组在排序后,将一个值(第二个参数)插入该数组,并使数组保持有序。返回这个新插入元素的**最小**索引值(应为一个数字)。
|
|
|
|
|
|
|
|
|
|
例如,`getIndexToIns([1,2,3,4], 1.5)` 应该返回 `1` 因为 `1.5` 大于 `1`(索引为 0)且小于 `2`(索引为 1)。
|
|
|
|
|
|
|
|
|
|
同样地,`getIndexToIns([20,3,5], 19)` 应该返回 `2`。因为数组排序后会变成 `[3,5,20]`,而 `19` 小于 `20`(索引为 2)且大于 `5`(索引为 1)。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
|
|
|
|
# --hints--
|
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([10, 20, 30, 40, 50], 35)` 应返回 `3`。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
assert(getIndexToIns([10, 20, 30, 40, 50], 35) === 3);
|
|
|
|
|
```
|
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([10, 20, 30, 40, 50], 35)` 应返回一个数字。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
assert(typeof getIndexToIns([10, 20, 30, 40, 50], 35) === 'number');
|
|
|
|
|
```
|
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([10, 20, 30, 40, 50], 30)` 应返回 `2`。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
assert(getIndexToIns([10, 20, 30, 40, 50], 30) === 2);
|
|
|
|
|
```
|
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([10, 20, 30, 40, 50], 30)` 应返回一个数字。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
assert(typeof getIndexToIns([10, 20, 30, 40, 50], 30) === 'number');
|
|
|
|
|
```
|
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([40, 60], 50)` 应返回 `1`。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
assert(getIndexToIns([40, 60], 50) === 1);
|
|
|
|
|
```
|
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([40, 60], 50)` 应返回一个数字。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
assert(typeof getIndexToIns([40, 60], 50) === 'number');
|
|
|
|
|
```
|
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([3, 10, 5], 3)` 应返回 `0`。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
assert(getIndexToIns([3, 10, 5], 3) === 0);
|
|
|
|
|
```
|
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([3, 10, 5], 3)` 应返回一个数字。
|
2020-12-16 00:37:30 -07:00
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
assert(typeof getIndexToIns([3, 10, 5], 3) === 'number');
|
|
|
|
|
```
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([5, 3, 20, 3], 5)` 应返回 `2`。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
```js
|
|
|
|
|
assert(getIndexToIns([5, 3, 20, 3], 5) === 2);
|
|
|
|
|
```
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([5, 3, 20, 3], 5)` 应返回一个数字。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
```js
|
|
|
|
|
assert(typeof getIndexToIns([5, 3, 20, 3], 5) === 'number');
|
2018-10-10 18:03:03 -04:00
|
|
|
|
```
|
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([2, 20, 10], 19)` 应返回 `2`。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
```js
|
|
|
|
|
assert(getIndexToIns([2, 20, 10], 19) === 2);
|
|
|
|
|
```
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([2, 20, 10], 19)` 应返回一个数字。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
|
|
|
|
```js
|
2020-12-16 00:37:30 -07:00
|
|
|
|
assert(typeof getIndexToIns([2, 20, 10], 19) === 'number');
|
|
|
|
|
```
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([2, 5, 10], 15)` 应返回 `3`。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
```js
|
|
|
|
|
assert(getIndexToIns([2, 5, 10], 15) === 3);
|
2018-10-10 18:03:03 -04:00
|
|
|
|
```
|
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([2, 5, 10], 15)` 应返回一个数字。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
```js
|
|
|
|
|
assert(typeof getIndexToIns([2, 5, 10], 15) === 'number');
|
|
|
|
|
```
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([], 1)`应该返回 `0`。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
```js
|
|
|
|
|
assert(getIndexToIns([], 1) === 0);
|
|
|
|
|
```
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
2021-01-12 08:18:51 -08:00
|
|
|
|
`getIndexToIns([], 1)` 应返回一个数字。
|
2018-10-10 18:03:03 -04:00
|
|
|
|
|
|
|
|
|
```js
|
2020-12-16 00:37:30 -07:00
|
|
|
|
assert(typeof getIndexToIns([], 1) === 'number');
|
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 getIndexToIns(arr, num) {
|
|
|
|
|
return num;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
getIndexToIns([40, 60], 50);
|
|
|
|
|
```
|
|
|
|
|
|
2020-12-16 00:37:30 -07:00
|
|
|
|
# --solutions--
|
|
|
|
|
|
2021-01-13 03:31:00 +01:00
|
|
|
|
```js
|
|
|
|
|
function getIndexToIns(arr, num) {
|
|
|
|
|
arr = arr.sort((a, b) => a - b);
|
|
|
|
|
|
|
|
|
|
for (let i = 0; i < arr.length; i++) {
|
|
|
|
|
if (arr[i] >= num) {
|
|
|
|
|
return i;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return arr.length;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
getIndexToIns([40, 60], 50);
|
|
|
|
|
```
|