LeetCode 1838. Frequency of the Most Frequent Element
原题链接在这里:https://leetcode.com/problems/frequency-of-the-most-frequent-element/
题目:
The frequency of an element is the number of times it occurs in an array.
You are given an integer array nums
and an integer k
. In one operation, you can choose an index of nums
and increment the element at that index by 1
.
Return the maximum possible frequency of an element after performing at most k
operations.
Example 1:
Input: nums = [1,2,4], k = 5 Output: 3 Explanation: Increment the first element three times and the second element two times to make nums = [4,4,4]. 4 has a frequency of 3.
Example 2:
Input: nums = [1,4,8,13], k = 5 Output: 2 Explanation: There are multiple optimal solutions: - Increment the first element three times to make nums = [4,4,8,13]. 4 has a frequency of 2. - Increment the second element four times to make nums = [1,8,8,13]. 8 has a frequency of 2. - Increment the third element five times to make nums = [1,4,13,13]. 13 has a frequency of 2.
Example 3:
Input: nums = [3,9,6], k = 2 Output: 1
Constraints:
1 <= nums.length <= 105
1 <= nums[i] <= 105
1 <= k <= 105
题解:
Try to put similar elements together. Sort the array.
Use sliding window. When sum + k >= max * windows size. Then the whole window could be max after k operations.
Time Complexity: O(nlogn). n = nums.length.
Space: O(1).
AC Java:
1 class Solution { 2 public int maxFrequency(int[] nums, int k) { 3 if(nums == null || nums.length == 0){ 4 return 0; 5 } 6 7 Arrays.sort(nums); 8 int walker = 0; 9 int runner = 0; 10 long sum = 0; 11 int res = 0; 12 while(runner < nums.length){ 13 sum += nums[runner]; 14 while(sum + k < (long)nums[runner] * (runner - walker + 1)){ 15 sum -= nums[walker++]; 16 } 17 18 res = Math.max(res, runner - walker + 1); 19 runner++; 20 } 21 22 return res; 23 } 24 }