※ 引述《JerryChungYC (JerryChung)》之铭言:
: https://leetcode.com/problems/sort-array-by-increasing-frequency
: 1636. Sort Array by Increasing Frequency
: 给一个整数数组 nums ,依照值出现的频率进行升序排序
: 如果多个值有相同的频率,则这些值按降序进行排序
: Example 1:
: Input: nums = [1,1,2,2,2,3]
: Output: [3,1,1,2,2,2]
: Example 2:
: Input: nums = [2,3,1,3,2]
: Output: [1,3,3,2,2]
: Explanation: 2跟3的频率相同,降序为3>2
: Example 3:
: Input: nums = [-1,1,-6,4,5,-6,1,4,1]
: Output: [5,-1,4,4,-6,-6,1,1,1]
: 思路:
: 先计算出频率,排序后再根据次数重复放入
: Python Code:
: class Solution:
: def frequencySort(self, nums: List[int]) -> List[int]:
: result = []
: for key, count in sorted(Counter(nums).items(), key=lambda x: (x[1], -x[0])):
: result.extend([key] * count)
: return result
: 因为相同频率要降序 所以用(x[1], -x[0])
思路:
差不多 不过我写得好丑 有空研究一下Counter好了 感觉很方便
Python Code:
class Solution:
def frequencySort(self, nums: List[int]) -> List[int]:
record = defaultdict(int)
for n in nums:
record[n] += 1
sorted_pairs = sorted([(x,y) for x,y in record.items()],key = lambda
x : (x[1],-x[0]))
result = []
while sorted_pairs:
x,y = sorted_pairs.pop(0)
for _ in range(y):
result.append(x)
return result