排工资-稳定地按频率排序

某公司中有N名员工。给定所有员工工资的清单,财务人员要按照待定的顺序排列员工的工资。他按照工资的频次降序排列,即给定清单中所有频次较高的工资将在频次较低的工资之前出现。如果相同数量的员工都有相同的工资,则将按照给定清单中该工资第一次出现的顺序排列。
写一个算法来帮助财务人员排列员工工资的顺序。

输入

salaries,一个正整数列表,表示N名员工的工资。

输出
返回一个正整数列表,该列表按照员工工资的频次排序。

约束条件
1≤num≤10^5
1≤salaries[i]≤10^9
0≤i<num

示例
输入:
salaries=[10000,20000,40000,30000,30000,30000,40000,20000,50000,50000,50000,50000,60000,60000,60000,70000,80000,90000,100000]

输出:

[50000,50000,50000,50000,30000,30000,30000,60000,60000,60000,20000,20000,40000,40000,10000,70000,80000,90000,100000]

#include<vector>
#include<map>
#include<iostream>
#include<algorithm>
using namespace std;
vector<int> in{ 10000,20000,40000,30000,30000,30000,40000,20000,50000,50000,50000,50000,60000,60000,60000,70000,80000,90000,100000 };
bool freqency(const pair<int, int> &a, const pair<int, int> &b) 
{
     return a.second > b.second;
}
int main() {
	map<int, int> zq; 
	vector<pair<int, int>>re;
	for (auto temp : in)
		++zq[temp];
	for (auto i = 0; i < in.size(); ++i)
	{
		if (zq[in[i]]!=0)
		{
			re.push_back(make_pair(in[i], zq[in[i]]));
			zq[in[i]] = 0;
		}
	}
	stable_sort(re.begin(),re.end(),freqency);
	for (auto &haha : re)
	{
		for(int i=0;i<haha.second;++i)
		cout << haha.first << " ";
	}
	system("pause");
	return 0;
}



全部评论
牛逼
点赞 回复
分享
发布于 2019-08-17 14:59

相关推荐

点赞 评论 收藏
转发
2 收藏 评论
分享
牛客网
牛客企业服务