-
Notifications
You must be signed in to change notification settings - Fork 70
/
Copy pathres.js
60 lines (51 loc) · 1.47 KB
/
res.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
/**
* 归并排序+索引数组
* @param {number[]} nums
* @return {number[]}
*/
var countSmaller = function(nums) {
const len = nums.length;
if (!len) return [];
if (len === 1) return [0];
const indexList = nums.map((e, i) => i);
const res = nums.map(() => 0);
const helper = (nums, left, right, indexList) => {
let mid = -1;
if (left === right) {
return ;
}
mid = left + parseInt((right - left) / 2);
// 计算一下左边
helper(nums, left, mid, indexList)
// 计算一下右边
helper(nums, mid + 1, right, indexList)
if(nums[indexList[mid]] < nums[indexList[mid+1]])
return ;
// 两个子序列合并
sort_and_count_smaller(nums, left, mid, right, indexList);
}
const sort_and_count_smaller = (nums, left, mid, right, indexList) => {
const temp = indexList.slice();
let l = left;
let r = mid + 1;
for (let i = l; i <= right; i++) {
if (l > mid) { // 左边遍历完
indexList[i] = temp[r];
r += 1;
} else if (r > right) { // 右边遍历完
indexList[i] = temp[l];
l += 1;
res[indexList[i]] += (right-mid);
} else if (nums[temp[l]] <= nums[temp[r]]) { //
indexList[i] = temp[l];
l += 1;
res[indexList[i]] += (r - mid - 1);
} else if (nums[temp[l]] > nums[temp[r]]) {
indexList[i] = temp[r];
r += 1;
}
}
}
helper(nums, 0, len-1, indexList);
return res;
};