「 每日一练,快乐水题 」1636. 按照频率将数组升序排序
Posted 谁吃薄荷糖
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了「 每日一练,快乐水题 」1636. 按照频率将数组升序排序相关的知识,希望对你有一定的参考价值。
文章目录
🔴力扣原题:
🟠题目简述:
给你一个整数数组 nums ,请你将数组按照每个值的频率 升序 排序。如果有多个值的频率相同,请你按照数值本身将它们 降序 排序。
请你返回排序后的数组。
示例 1:
输入:nums = [1,1,2,2,2,3]
输出:[3,1,1,2,2,2]
解释:‘3’ 频率为 1,‘1’ 频率为 2,‘2’ 频率为 3 。
示例 2:
输入:nums = [2,3,1,3,2]
输出:[1,3,3,2,2]
解释:‘2’ 和 ‘3’ 频率都为 2 ,所以它们之间按照数值本身降序排序。
示例 3:
输入:nums = [-1,1,-6,4,5,-6,1,4,1]
输出:[5,-1,4,4,-6,-6,1,1,1]
提示:
1 <= nums.length <= 100
-100 <= nums[i] <= 100
🟡解题思路:
法一 杀鸡用牛刀,不走寻常路
- 模拟大法好;
- 利用
undered_map
把nums
数据频次计算完毕; - 把
undered_map
进行自定义排序,把unoderer_map
数据组成pair
插入到vector
中; - 利用
sort
函数按照value
进行排序; - 编写比较函数,over;
cmp
函数需要加static
,否则会报错reference to non-static member function must be called
法二 常规路线,正规军
- 模拟大法好;
- 利用
sort
函数对结合undered_map
中nums
数据的频次对nums
进行自定义排序; - over;
🟢C++代码:
法一
class Solution
public:
static bool cmp(const pair<int, int> &a, const pair<int, int> &b)
if(a.second != b.second)
return a.second < b.second;
return a.first > b.first;
vector<int> frequencySort(vector<int>& nums)
unordered_map<int, int> umap;
for(auto & num : nums)
++umap[num];
vector<pair<int, int>> vec(umap.begin(), umap.end());
sort(vec.begin(), vec.end(), cmp);
vector<int> res;
for(int i = 0; i < vec.size(); i++)
for(int j = 0; j < vec[i].second; j++)
res.push_back(vec[i].first);
return res;
;
法二
class Solution
public:
vector<int> frequencySort(vector<int>& nums)
unordered_map<int, int> umap;
for(auto & num : nums)
++umap[num];
//func 2
sort(nums.begin(), nums.end(),
[&](int a, int b)
if(umap[a] != umap[b])
return umap[a] < umap[b];
return a > b ;
);
return nums;
;
🔵结果展示:
法一
法二
以上是关于「 每日一练,快乐水题 」1636. 按照频率将数组升序排序的主要内容,如果未能解决你的问题,请参考以下文章
「 每日一练,快乐水题 」1636. 按照频率将数组升序排序