zoukankan      html  css  js  c++  java
  • leetcode 1365 有多少小于当前数字的数字

    给你一个数组 nums,对于其中每个元素 nums[i],请你统计数组中比它小的所有数字的数目。

    换而言之,对于每个 nums[i] 你必须计算出有效的 j 的数量,其中 j 满足 j != i 且 nums[j] < nums[i] 。

    以数组形式返回答案。

    示例 1: 

    输入:nums = [8,1,2,2,3]           

    输出:[4,0,1,1,3]

    解释:
    对于 nums[0]=8 存在四个比它小的数字:(1,2,2 和 3)。
    对于 nums[1]=1 不存在比它小的数字。
    对于 nums[2]=2 存在一个比它小的数字:(1)。
    对于 nums[3]=2 存在一个比它小的数字:(1)。
    对于 nums[4]=3 存在三个比它小的数字:(1,2 和 2)。

    示例 2:

    输入:nums = [6,5,4,8]

    输出:[2,1,0,3]

    示例 3:

    输入:nums = [7,7,7,7]

    输出:[0,0,0,0]

    截题思路:先排序,然后用HashMap存储小于单独个数的数,然后对应生成数组。

    import java.util.Arrays;
    import java.util.HashMap;
    class Solution {
        public int[] smallerNumbersThanCurrent(int[] nums) {
            HashMap<Integer, Integer> hashMap = new HashMap<Integer, Integer>();
    		int[] arr1 = new int[nums.length];
    		for (int count = 0; count < nums.length; count++) {
    			arr1[count] = nums[count];
    		}
    		Arrays.sort(arr1);
    		int count2 = arr1.length - 2;
    		int count1 = arr1.length - 1;
    		while (count2 >= 0) {
    			if (arr1[count2] == arr1[count1]) {
    				count2--;
    				if (count2 == -1) {
    					hashMap.put(arr1[count2+1], 0);
    				}
    			} else {
    				hashMap.put(arr1[count1], count2 + 1);
    				count1 = count2;
    				count2 = count1;
    			}
    		}
    		int[] resultarr = new int[nums.length];
    		for (int count = 0; count < resultarr.length; count++) {
    			resultarr[count] = hashMap.get(nums[count]);
    		}
    		return resultarr;
        }
    }
    

     来源:力扣(LeetCode)

    链接:https://leetcode-cn.com/problems/how-many-numbers-are-smaller-than-the-current-number
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/how-many-numbers-are-smaller-than-the-current-number
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

  • 相关阅读:
    品Spring:实现bean定义时采用的“先进生产力”
    品Spring:bean定义上梁山
    品Spring:帝国的基石
    【面试】我是如何在面试别人Redis相关知识时“软怼”他的
    【面试】足够“忽悠”面试官的『Spring事务管理器』源码阅读梳理(建议珍藏)
    睡梦中被拉起来执行Spring事务
    Middleware的艺术
    突破自我,开源NetWorkSocket通讯组件
    化茧成蝶,开源NetWorkSocket通讯组件
    理解IEnumerator+IEnumerable这种接口思想
  • 原文地址:https://www.cnblogs.com/longlyseul/p/12482164.html
Copyright © 2011-2022 走看看