一开始想得可复杂了,复制一下整个数组,给复制的数组排序,然后再把结果存到一个哈希表里,再把哈希表的数据映射到答案数组...看了题解学了一下标准的计数法
解题思路
- 考虑到对于所有的数字,都小于100,故定义一个cnt数组存储这些数组出现的次数,其大小为101;
- 从cnt[1]开始,对cnt数组进行累加操作,得到对于每个数字 i (对应nums内的元素),其前面数字出现的次数;
- 将结果写入答案数组ans[ ],由于此时cnt[ ]数组内每个元素存储的是从0到 i 本身出现的次数,符合题意的计数应该是cnt[nums[i] - 1]。
Java代码
class Solution {
public int[] smallerNumbersThanCurrent(int[] nums) {
int[] cnt = new int[101];
int n = nums.length;
int[] ans = new int[n];
//计数
for (int element : nums) {
cnt[element]++;
}
for (int i = 1; i < 101; i++) {
cnt[i] += cnt[i-1];
}
//装填
for (int i = 0; i < n; i++) {
ans[i] = nums[i] == 0 ? 0 : cnt[nums[i] - 1];
}
return ans;
}
}

本文介绍了一种利用计数法解决LeetCode题目1365:有多少小于当前数字的数字的方法。通过定义一个大小为101的数组来存储每个数字出现的次数,并对数组进行累加,最终映射到答案数组中。
303

被折叠的 条评论
为什么被折叠?



