当前位置:网站首页>力扣练习——61 根据字符出现频率排序
力扣练习——61 根据字符出现频率排序
2022-08-10 10:59:00 【qq_43403657】
61 根据字符出现频率排序
1.问题描述
给定一个字符串,请将字符串里的字符按照出现的频率降序排列,如果频率相同,则按照字符的ASCII码升序排列。
示例 1:
输入:
“tree”
输出:
“eert”
解释:
'e’出现两次,'r’和’t’都只出现一次。
因此’e’必须出现在’r’和’t’之前,而且’r’比’t’的ASCII码小。
示例 2:
输入:
“cccaaa”
输出:
“aaaccc”
解释:
'c’和’a’都出现三次。因此按照字符升序排列,'a’在’c’前。
示例 3:
输入:
“Aabb”
输出:
“bbAa”
解释:
'A’和’a’被认为是两种不同的字符,并且’A’的ASCII码比’a’小
2.输入说明
输入一个字符串
3.输出说明
输出一个字符串,字符串中字符的顺序请参考以上说明。
4.范例
输入
Aabb
输出
bbAa
5.代码
#include<iostream>
#include<map>
#include<string>
#include<unordered_map>
#include<algorithm>
using namespace std;
bool cmp(pair<char, int> a, pair<char, int>b)
{
return a.second == b.second?a.first<b.first:a.second>b.second;//该题目中最关键的部分,注意写法!
}
string OrderbyChar(string s)
{
//给定一个字符串,请将字符串里的字符按照出现的频率降序排列,如果频率相同,则按照字符的ASCII码升序排列。
string res;//结果字符串
unordered_map<char, int>hash;//记录每个字符出现次数
vector<pair<char, int> > v;//使用pair记录对应关系
for (auto c : s)//遍历字符串
hash[c]++;
for (auto it : hash)
v.emplace_back(it);//直接将每个hash元素插入v中
sort(v.begin(), v.end(), cmp);
for (int i = 0; i < v.size(); i++)
{
while (v[i].second--)
res += v[i].first;
}
return res;
}
int main()
{
string s;
cin >> s;
string res = OrderbyChar(s);
cout << res << endl;
return 0;
}
边栏推荐
- 零基础想自学软件测试,有没有大佬可以分享下接下来的学习书籍和路线?
- 动作捕捉系统用于室内组合定位技术研究
- 建校仅11年就入选“双一流” ,这所高校是凭什么做到的?
- 负载均衡原理分析与源码解读
- [Go WebSocket] 多房间的聊天室(一)思考篇
- What is affecting MySQL performance?
- 杭电多校-Loop-(不确定性贪心+线段树)
- 基于UiAutomator2+PageObject模式开展APP自动化测试实战
- [Brave food, not afraid of the linked list of brushing questions] Merging of ordered linked lists
- 2023版揽胜运动曝光,安全、舒适一个不落
猜你喜欢
随机推荐
Nocalhost - 让云原生时代的开发更高效
负载均衡原理分析与源码解读
实现内网穿透的最佳解决方案(无实名认证,完全免费)
【勇敢饭饭,不怕刷题之链表】有序链表的合并
Alibaba最新神作!耗时182天肝出来1015页分布式全栈手册太香了
什么是幂等性?四种接口幂等性方案详解!
Gold, nine, silver and ten job-hopping seasons: technical interview questions and answers on Alibaba, Baidu, JD.com, and Meituan
十年架构五年生活-09 五年之约如期而至
第3章-线性方程组(3)
LeetCode_152_乘积最大子数组
STM32封装ESP8266一键配置函数:实现实现AP模式和STA模式切换、服务器与客户端创建
接口定义与实现
开发模式对测试的影响
一文带你搞懂中断按键驱动程序之poll机制
如何使用工程仪器设备在线监测管理系统
L2 applications from a product perspective: why is it a playground?
flask-restplus接口地址404问题
CPU多级缓存与缓存一致性
runtime-core.esm-bundler.js?d2dd:218 Uncaught TypeError: formRef.value?.validate is not a function
rider内Mono脚本找不到引用资源









