1. 程式人生 > 實用技巧 >1365. 有多少小於當前數字的數字

1365. 有多少小於當前數字的數字

給你一個數組nums,對於其中每個元素nums[i],請你統計陣列中比它小的所有數字的數目。
換而言之,對於每個nums[i]你必須計算出有效的j的數量,其中 j 滿足j != i 且 nums[j] < nums[i]。
以陣列形式返回答案。

輸入: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)。

//1.暴力法,雙迴圈遍歷陣列
class Solution {
    public int[] smallerNumbersThanCurrent(int[] nums) {
        int length = nums.length;
        int[] res = new int[length];

        for(int i=0;i<length;i++){
            int count = 0;
            for(int j=0;j<length;j++){
                if(nums[i]!=nums[j]&&nums[j]<nums[i])
                    count++;
            }
            res[i]=count;
        }
        return res;
    }
}

//2.記錄每個數出現的次數count,利用for迴圈從頭開始排序,所有比當前數小的都會在左邊,有多少個就算count的和
class Solution {
    public int[] smallerNumbersThanCurrent(int[] nums) {
        int[] count = new int[101];
        int length = nums.length;
        int[] res = new int[length];

        for(int i=0;i<length;i++){// 記錄每個數出現次數
            count[nums[i]]++;
        }
        for(int j=1;j<101;j++){  // 記錄所有<i出現次數
            count[j]+=count[j-1];
        }
        for(int i=0;i<length;i++){
            res[i]= nums[i]==0?0:count[nums[i]-1];
        }
        return res;
    }
}