LeetCode 451 根据字符出现频率排序 中等

2023-10-29 12:44

本文主要是介绍LeetCode 451 根据字符出现频率排序 中等,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目 - 点击直达

  • 1. 451 根据字符出现频率排序 中等
    • 1. 题目详情
      • 1. 原题链接
      • 2. 题目要求
      • 3. 基础框架
    • 2. 解题思路
      • 1. 思路分析
      • 2. 时间复杂度
      • 3. 代码实现

1. 451 根据字符出现频率排序 中等

1. 题目详情

给定一个字符串 s ,根据字符出现的 频率 对其进行 降序排序 。一个字符出现的 频率 是它出现在字符串中的次数。

返回 已排序的字符串 。如果有多个答案,返回其中任何一个。

1. 原题链接

LeetCode 451 根据字符出现频率排序 中等

2. 题目要求

示例 1:

输入: s = “tree”
输出: “eert”
解释: 'e’出现两次,'r’和’t’都只出现一次。
因此’e’必须出现在’r’和’t’之前。此外,"eetr"也是一个有效的答案。
示例 2:

输入: s = “cccaaa”
输出: “cccaaa”
解释: 'c’和’a’都出现三次。此外,"aaaccc"也是有效的答案。
注意"cacaca"是不正确的,因为相同的字母必须放在一起。
示例 3:

输入: s = “Aabb”
输出: “bbAa”
解释: 此外,"bbaA"也是一个有效的答案,但"Aabb"是不正确的。
注意’A’和’a’被认为是两种不同的字符。

提示:

1 <= s.length <= 5 * 105
s 由大小写英文字母和数字组成

3. 基础框架

● Cpp代码框架

class Solution {
public:string frequencySort(string s) {
};

2. 解题思路

1. 思路分析

( 1 ) (1) (1) 哈希思想,所有可能的字符共有 62 62 62个,开辟一个大小为62的整型数组与每个字符建立唯一映射,整型数组存放每个字符出现的次数;
( 2 ) (2) (2) 题目要求按照出现次数排序字符串,对统计了字符个数的整型数组排序后映射关系将会失效,所以需要新的字符数组记录整型数组对应位置的字符;
( 3 ) (3) (3) 初始化整型数组内容和字符数组内容
( 4 ) (4) (4) 遍历字符串统计字符出现字数并存放在整型数组对应位置;
( 5 ) (5) (5) 同时对整型数组和字符数组排序,字符数组的元素随整型数组的元素移动而移动,这样就保证了排序后整型数组字符出现的次数按降序排列,字符数组元素一一对应整型数组元素;
( 6 ) (6) (6) 依次把字符数组字符尾插到空string对象中,字符在整型数组中出现几次就尾插几次;

2. 时间复杂度

O ( N ) O(N) O(N)

3. 代码实现

class Solution {
public:string frequencySort(string s) {// 哈希思想映射// 额外字符数组记录整型数组映射的字符int n = 62;int arr1[n];memset(arr1, 0, n * sizeof(int));char arr2[n];// ['a', 'z'] [0, 25]// ['A', 'Z'] [26, 51]// ['0', '9'] [52, 61]for(int i = 0, j = 0; i < n; ++i, ++j){if(i < 26)arr2[i] = 'a' + j;else if(i < 52)arr2[i] = 'A' + j % 26;elsearr2[i] = '0' + j % 52;}// 统计字符串字符出现次数,使用整型数组映射for(auto & e : s){char c;if(islower(e)) arr1[e - 'a']++;else if(isupper(e)) arr1[e - 'A' + 26]++;else arr1[e - '0' + 52]++;}// 按照出现次数对整型数组排序,字符数组随整型数组而排序,保证对应下标位置的字符和出现次数依然对应sorts(arr1, arr2, n);// 遍历按降序排好的整型数组,对应字符数组中的字符顺序就是按照字符出现次序降序排列的// 依次把字符数组字符尾插到空string对象中,出现几次就尾插几次string ret;for(int i = 0; i < n; ++i){for(int j = 0; j < arr1[i]; ++j){ret += arr2[i];}}return ret;}void sorts(int* arr1, char* arr2, int n){for(int i = 0; i < n; ++i){bool flag = true; // 默认有序, 如果真有序就提前结束排序for(int j = 0; j < n - i - 1; ++j){if(arr1[j] < arr1[j + 1]){swap(arr1[j], arr1[j + 1]);swap(arr2[j], arr2[j + 1]);flag = false;}}if(flag) break;}}
};

这篇关于LeetCode 451 根据字符出现频率排序 中等的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/300742

相关文章

一文详解Java Stream的sorted自定义排序

《一文详解JavaStream的sorted自定义排序》Javastream中的sorted方法是用于对流中的元素进行排序的方法,它可以接受一个comparator参数,用于指定排序规则,sorte... 目录一、sorted 操作的基础原理二、自定义排序的实现方式1. Comparator 接口的 Lam

C#如何去掉文件夹或文件名非法字符

《C#如何去掉文件夹或文件名非法字符》:本文主要介绍C#如何去掉文件夹或文件名非法字符的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#去掉文件夹或文件名非法字符net类库提供了非法字符的数组这里还有个小窍门总结C#去掉文件夹或文件名非法字符实现有输入字

Java List排序实例代码详解

《JavaList排序实例代码详解》:本文主要介绍JavaList排序的相关资料,Java排序方法包括自然排序、自定义排序、Lambda简化及多条件排序,实现灵活且代码简洁,文中通过代码介绍的... 目录一、自然排序二、自定义排序规则三、使用 Lambda 表达式简化 Comparator四、多条件排序五、

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

idea报错java: 非法字符: ‘\ufeff‘的解决步骤以及说明

《idea报错java:非法字符:‘ufeff‘的解决步骤以及说明》:本文主要介绍idea报错java:非法字符:ufeff的解决步骤以及说明,文章详细解释了为什么在Java中会出现uf... 目录BOM是什么?1. BOM的作用2. 为什么会出现 \ufeff 错误?3. 如何解决 \ufeff 问题?最

使用Java编写一个字符脱敏工具类

《使用Java编写一个字符脱敏工具类》这篇文章主要为大家详细介绍了如何使用Java编写一个字符脱敏工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、字符脱敏工具类2、测试工具类3、测试结果1、字符脱敏工具类import lombok.extern.slf4j.Slf4j

解决IDEA报错:编码GBK的不可映射字符问题

《解决IDEA报错:编码GBK的不可映射字符问题》:本文主要介绍解决IDEA报错:编码GBK的不可映射字符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录IDEA报错:编码GBK的不可映射字符终端软件问题描述原因分析解决方案方法1:将命令改为方法2:右下jav

Mybatis 传参与排序模糊查询功能实现

《Mybatis传参与排序模糊查询功能实现》:本文主要介绍Mybatis传参与排序模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、#{ }和${ }传参的区别二、排序三、like查询四、数据库连接池五、mysql 开发企业规范一、#{ }和${ }传参的

C++快速排序超详细讲解

《C++快速排序超详细讲解》快速排序是一种高效的排序算法,通过分治法将数组划分为两部分,递归排序,直到整个数组有序,通过代码解析和示例,详细解释了快速排序的工作原理和实现过程,需要的朋友可以参考下... 目录一、快速排序原理二、快速排序标准代码三、代码解析四、使用while循环的快速排序1.代码代码1.由快

C语言字符函数和字符串函数示例详解

《C语言字符函数和字符串函数示例详解》本文详细介绍了C语言中字符分类函数、字符转换函数及字符串操作函数的使用方法,并通过示例代码展示了如何实现这些功能,通过这些内容,读者可以深入理解并掌握C语言中的字... 目录一、字符分类函数二、字符转换函数三、strlen的使用和模拟实现3.1strlen函数3.2st