java数据结构与算法刷题-----LeetCode451. 根据字符出现频率排序

java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/123063846

文章目录

    • 1. hash统计出现次数后排序
    • 2. 桶排序

在这里插入图片描述

1. hash统计出现次数后排序

解题思路:时间复杂度O( ) ,空间复杂度 O ( ),空间复杂度O( ),空间复杂度O()
  1. 通过hash表统计每个字符的出现次数,时间复杂度O( n n n)
  2. 对hash表按照出现次数降序排序,时间复杂度O( k ∗ l o g 2 k k*log_2{k} klog2k)是快速排序的时间复杂度。其中k是hash大小,也就是字符串中不重复的字母个数

如果使用数组作为hash表,不使用HashMap的话,则不需要排序

  1. 然后依次将最大出现次数的字符,拼接起来,输出。正好是按照排序好的hash表进行输出。O( k k k)

使用数组作为hash表,虽然不需要排序,但是每次都得遍历整个hash表找到出现次数最多的字符。因此时间复杂度O( n ∗ k n*k nk)其中n是字符串大小,k是hash表大小。我们需要找到n个字符拼接为结果字符串,每次都需要完整遍历hash表(长度为k)找到出现次数最多的

  1. 因此时间复杂度为
  1. 直接使用HashMap,时间复杂度O( n + k ∗ l o g 2 k n+k*log_2{k} n+klog2k),空间复杂度O( n + k n+k n+k).另外快速排序也需要额外栈空间O( l o g 2 k log_2{k} log2k)
  2. 使用数组作为hash表,时间复杂度O( n + n ∗ k n+n*k n+nk),空间复杂度O(n+k).

使用数组作为hash表所需大小:
字符串包含大小写字母和数字,ASCII码如下:A = 65,Z = 90. a = 97,z = 122,0 = 48,9 = 57
因此hash表大小为123即可(下标从0到122)。并且从48开始,前面47的下标是没有用的

代码:选用数组作为hash,因为这样更难,做题情况下,比使用HashMap效率高很多(工作场景下没什么区别)。但是工作场景中,要使用HashMap。

在这里插入图片描述

class Solution {public String frequencySort(String s) {int[] list = new int[123];//hash表char[] chars = s.toCharArray();//获取字符数组for (int i = 0; i < chars.length; i++) {//统计每个字符出现的次数int n = (int) chars[i];//获取当前字符的ASCII码list[n]++;//对应hash位置+1}int index = 0;//结果字符数组的下标while (index < chars.length) {int max = 0;//保存最大值char target = ' ';//保存出现次数最多的字符for (int i = 48; i < list.length; i++) {//遍历hash表if (list[i] > max) {//如果当前字符出现次数更多max = list[i];//保存这个次数target = (char) i ;//让target指向这个字符}}for (int j = 0; j < max; j++) {//将其拼接到字符数组中chars[index++] = target;}list[target] = 0;//hash表中已经输出的字符归0}return String.valueOf(chars);}
}

2. 桶排序

解题思路:时间复杂度O( n + k n+k n+k),空间复杂度O( n + k n+k n+k)
  1. 先通过hash表统计每个字符的出现次数,时间复杂度O( n n n)
  2. 然后按照出现次数,将字符放入对应桶中。时间复杂度O( k k k)

桶保存的是对应出现次数的字符。例如1号桶保存出现1次的字符,2号桶保存出现次数为2的字符

  1. 然后从后往前遍历桶(出现次数高的先拼接到字符串)。时间复杂度O( k k k)

记住,当前是几号桶,取出的字符就出现几次。因此我们拼接字符串时,要将取出的字符每个都拼接对应桶的次数

代码:因为使用了StringBuilder,做题场景下的效率反而比方法1慢,但是实际工作场景中,肯定是这个方法的时间复杂度更优

在这里插入图片描述

class Solution {public String frequencySort(String s) {char[] charArray = s.toCharArray();int[] freq = new int[128]; // 使用128大小的数组,考虑到ASCII码表StringBuilder[] buckets = new StringBuilder[s.length() + 1];//桶,个数为字符串中字符个数+1// 统计字符出现频率for (char c : charArray) freq[c]++;// 将字符按照频率放入对应的桶中,出现次数是几,就放入几号桶for (int i = 48; i < 128; i++) {if (freq[i] > 0) {//如果当前字符出现次数>0//放入对应出现次数的桶中,例如当前字符出现3次,就放入3号桶if (buckets[freq[i]] == null) buckets[freq[i]] = new StringBuilder();//如果当前桶为空,先创建桶buckets[freq[i]].append((char)i);//然后将字符添加到桶中}}// 构建结果字符串StringBuilder result = new StringBuilder();for (int i = buckets.length-1; i > 0; i--) {//从后往前遍历桶if (buckets[i] != null) {//先查看,统计出现次数最高字符的桶for (char c : buckets[i].toString().toCharArray()) {//依次取出桶中字符for (int j = 0; j < i; j++) {//当前是i号桶,这个字符需要添加i次,因为i是它的出现次数result.append(c);}}}}return result.toString();}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/769494.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一个简单的内存缓存工具

缓存的数据是&#xff1a;List<User> Slf4j public class UserCache {private static volatile List<User> cacheDatas;private static volatile String expireTime;public static void set(List<User> datas, int expireSeconds) {long now DateTimeUtil.…

高性能 MySQL 第四版(GPT 重译)(二)

第四章&#xff1a;操作系统和硬件优化 你的 MySQL 服务器的性能只能和它最弱的环节一样好&#xff0c;而运行 MySQL 的操作系统和硬件通常是限制因素。磁盘大小、可用内存和 CPU 资源、网络以及连接它们的所有组件都限制了系统的最终容量。因此&#xff0c;你需要仔细选择硬件…

LEETCODE-DAY32

title: LEETCODE-DAY32 date: 2024-03-24 13:32:03 tags: 122.买卖股票的最佳时机II、55. 跳跃游戏、45.跳跃游戏II T1 class Solution:def maxProfit(self, prices: List[int]) -> int:result 0for i in range(1, len(prices)):result max(prices[i] - prices[i - 1],…

五款即将登陆Sui的游戏,总有一款适合你

在游戏领域不断演变的道路中&#xff0c;创新是吸引玩家注意力并保持他们参与的关键。展望今年余下的时间&#xff0c;Sui平台上即将推出的五款游戏将展示Web3游戏的可能性。通过运用强大的区块链技术和沉浸式叙事&#xff0c;这些游戏有望为玩家设定新的期望标准。 E4C: Fina…

【C语言】模拟实现 atoi

文章目录 atoi()函数模拟实现思路分析代码呈现 atoi()函数 通过上述cplusplus和MSDN对atoi函数的介绍我们可以得出以下几个关键点 库函数&#xff1a; <stdlib.h>形参&#xff1a;const char * str返回值&#xff1a; int作用&#xff1a;atoi函数是将一个字符串转化成一…

Windows 7 一键恢复 - 联想拯救系统

Windows 7 一键恢复 - 联想拯救系统 1. 联想拯救系统1.1. OEM 分区1.2. 一键恢复 References 1. 联想拯救系统 1.1. OEM 分区 计算机 -> 管理 -> 存储 -> 磁盘管理 1.2. 一键恢复 重新启动电脑 F11 -> 从初始备份恢复 References [1] Yongqiang Cheng, https…

福建科立讯通信 指挥调度管理平台 SQL注入漏洞复现(CVE-2024-2620、CVE-2024-2621)

0x01 产品简介 福建科立讯通信指挥调度管理平台是一个专门针对通信行业的管理平台。该产品旨在提供高效的指挥调度和管理解决方案,以帮助通信运营商或相关机构实现更好的运营效率和服务质量。该平台提供强大的指挥调度功能,可以实时监控和管理通信网络设备、维护人员和工作任…

java算法第34天 | 贪心算法 part03 ● 1005.K次取反后最大化的数组和 ● 134. 加油站 ● 135. 分发糖果

1005.K次取反后最大化的数组和 思路&#xff1a; 先将数组元素从小到大排列&#xff0c;从左向右处理&#xff0c;分两种情况讨论 当遇到负数&#xff0c;将负数变为正数&#xff0c;继续处理下一个元素当遇到正数&#xff0c;对数组重排&#xff0c;循环处理当前的最小元素。…

Python进程池回调

进程池在进程 发生错误/正常结束时&#xff0c;回调 import multiprocessing, time from functools import partialdef worker(i):print(f"Worker process {i} started")if i 5:raise Exception(f{i} error occured(自定义异常))time.sleep(5) # 模拟一些工作def …

leetcode最大连续1的个数(简单)

比较简单&#xff0c;但解时候如果能一次通过更好 方案一 public int findMaxConsecutiveOnes(int[] nums) {int i -1,j 0,max 0;while(j < nums.length && max < nums.length - i) {if(nums[j] ! 1) {i j;} else if(max < j - i){max j - i;}j;}return…

【重温设计模式】策略模式及其Java示例

策略模式的基本概念 策略模式&#xff0c;是一种常见的行为设计模式&#xff0c;主要用于处理程序中的一些相同行为&#xff0c;但具有不同实现方式的问题。在策略模式中&#xff0c;我们将每一种行为封装为一个个策略类&#xff0c;通过策略类的组合和切换&#xff0c;可以灵…

linux系统编程 socket part2

报式套接字 1.动态报式套接字2.报式套接字的广播3.报式套接字的多播4.UDP协议分析4.1.丢包原因4.2.停等式流量控制 接linux系统编程 socket part1 1.动态报式套接字 在之前的例子上&#xff0c;发送的结构体中的名字由定长改变长。可以用变长结构体。 变长结构体是由gcc扩展的…

mysql03

1.库(database)管理 建库 //创建数据库 create database db; //如果不存在db库,则跳过创库步骤,温和操作! create database if not exists db; //在db库存在的前提下重新创db库,举例效果如下: mysql> create database db; ERROR 1007 (HY000): Cant create database db; dat…

【RK android7.1 开机进入主界面前短暂黑屏或者白屏问题】

RK android7.1 开机进入主界面前短暂黑屏或者白屏问题 问题描述解决方法郑重声明:本人原创博文,都是实战,均经过实际项目验证出货的 转载请标明出处:攻城狮2015 Platform: Rockchip OS:Android 7.1.2 Kernel: 3.10 问题描述 开机进入主界面得一瞬间,launcher短暂黑屏或者白屏…

【python从入门到精通】--第一战:安装python

&#x1f308; 个人主页&#xff1a;白子寰 &#x1f525; 分类专栏&#xff1a;python从入门到精通&#xff0c;魔法指针&#xff0c;进阶C&#xff0c;C语言&#xff0c;C语言题集&#xff0c;C语言实现游戏&#x1f448; 希望得到您的订阅和支持~ &#x1f4a1; 坚持创作博文…

vue3封装leaflet并使用高德底图

该组件配置了高德和腾讯地图的底图。具有新建图层和打点&#xff08;使用leaflet中的方法&#xff09;&#xff0c;打点分为单个和多个。经纬度和详细地址的互相转换由高德api完成。 <template><div class"container"><!-- 搜索框 --><div cla…

Microsoft Word 快捷键 (keyboard shortcut - hotkey)

Microsoft Word 快捷键 [keyboard shortcut - hotkey] References 块复制 Alt 拖动选中 切换字母大小写 Shift F3 快速将光标移到文末 Ctrl End 快速将光标移到文首 Ctrl Home References [1] Yongqiang Cheng, https://yongqiang.blog.csdn.net/

MySQL中的基本SQL语句

文章目录 MySQL中的基本SQL语句查看操作创建与删除数据库和表修改表格数据库用户管理 MySQL中的基本SQL语句 查看操作 1. 查看有哪些数据库 show databases; 2.切换数据库 use 数据库名;比如切换至 mysql数据库 use mysql;3.查看数据库中的表 show tables;4.查看表中…

postgresql 数据库update 去重sql

1、先按重复记录fk分组找最小的记录&#xff0c;然后更新id 不在子查询中的数据 update td_f_stop_history set del_flag1 where "id" not in (select "min"("id") from td_f_stop_history where allowed_recover1 and del_flag0 group by fk…

Linux_进程概念_冯诺依曼_进程概念_查看进程_获取进程pid_创建进程_进程状态_进程优先级_环境变量_获取环境变量三种方式_3

文章目录 一、硬件-冯诺依曼体系结构二、软件-操作系统-进程概念0.操作系统做什么的1.什么叫做进程2.查看进程3.系统接口 获取进程pid- getpid4.系统接口 获取父进程pid - getppid5.系统接口 创建子进程 - fork1、手册2、返回值3、fork做了什么4、基本用法 6.进程的状态1、进程…