当前位置: 首页 > wzjs >正文

廊坊网站建设制作电话免费做产品画册的网站

廊坊网站建设制作电话,免费做产品画册的网站,网站的架设,北京做网络优化的公司一、哈希表相关理论 代码随想录刷题day15|(哈希表篇)242.有效的字母异位词、383.赎金信-CSDN博客 二、思路 首先,创建一个map集合,遍历字符串数组,对数组中每一个字符串(单词)比如"abc&…

一、哈希表相关理论

代码随想录刷题day15|(哈希表篇)242.有效的字母异位词、383.赎金信-CSDN博客

二、思路

首先,创建一个map集合,遍历字符串数组,对数组中每一个字符串(单词)比如"abc" 进行如下操作:创建一个长度为26的数组count,遍历当前字符串,计算出每个字母出现的次数,用count来存储元素中每个字母出现的次数,之后将数组count转换成对应字符串(通过sb,添加数组元素,然后toString);

map集合中的键就存放该频率字符串,也就是"1#1#1#0#...." (以"abc"为例);

map集合中键对应的值则存放 当前遍历(操作)的原数组中的字符串(字母)即 "abc";所以值的类型是列表 list<String>;

“abc” ---> [1,1,1,0,0.....] --->“#1#1#1#0.....”=key

map中添加的逻辑是:首先 判断该key是否存在,如果不存在,则创建一个ArrayList对象,如果存在,无需创建;

不管key存不存在,都要再将当前 处理的字符串“abc” 添加到list列表中["abc","acb","bca"];

那么最终,map中所有的值value 就是所有的字母异位词的分组,比如:

key:“#1#1#1#0.....”    value:["abc","acb","bca"]

key:"#0#1#1#1#0..."  value:["bcd","bdc","cdb"]

.......

最后获取map中的所有值的集合map.values(),返回(Collection<List<String>>);

也就是值是什么类型 外层再加一个collection;

new ArrayList<>(...)    将 Collection 转换为 List,确保返回类型正确且可修改;

核心思路

  1. 字母计数

    • 为每个单词创建一个长度为26的数组,统计每个字母出现的次数

    • 例如:"aab" → [2,1,0,0,...,0](a出现2次,b出现1次)

  2. 生成唯一键

    • 将计数数组转换为不可变的数据结构(如元组或字符串)作为哈希表的键

    • 例如:[2,1,0,...] → 转换为元组 (2,1,0,...) 或字符串 "2#1#0#..."

  3. 哈希表分组

    • 使用这个键将原始单词分组存储

三、相关题目

49.字母异位词分组

class Solution {public List<List<String>> groupAnagrams(String[] strs) {Map<String, List<String>> map = new HashMap<>();for(String str : strs){int[] count = new int[26];for(char c : str.toCharArray()){//int[] count = new int[26];count[c - 'a']++;}StringBuilder sb = new StringBuilder();for(int i : count){sb.append("#");sb.append(i);}String k = sb.toString();if(!map.containsKey(k)){List<String> list = new ArrayList<>();map.put(k, list);}map.get(k).add(str);}return new ArrayList<>(map.values());}}

四、总结

本题和有效的字母异位词不太一样,因为涉及到分组,怎么分组,怎么得到分组后的最终结果,但是最初处理字母异位词的逻辑相同,均使用数组;

还有最后的map集合put键值对的逻辑,如果按照下面的写法:

String k = sb.toString();
if(!map.containsKey(k)){//map中不包含kList<String> list = new ArrayList<>();list.add(str);map.put(k, list);
}

错因:只在key不存在时添加字符串,这样会漏掉后续相同key的字符串;

每次遇到一个字符串时,都创建了一个新的 ArrayList 并覆盖了 Map 中已有的值,这样会导致之前的同组异位词被覆盖丢失;

只有当key不存在时才创建新list;

无论key是否存在,都要将当前字符串添加到对应的list中;

http://www.dtcms.com/wzjs/542079.html

相关文章:

  • 网站建设都有什么功能做视频网站都需要什么软件
  • 最火爆的国际贸易网站广州网站设计开发公司
  • cms网站怎么做上海网站建设 虹口
  • 网站如何做百度推广方案wordpress后台图片无法显示
  • 网站建设代码标签大全深圳高端品牌网站建设
  • 如何建设好英文网站网络营销案例题
  • 南京 网站建站wordpress装修主题
  • 北京微信网站设计报价室内设计多少钱
  • 北京工商局网站怎么做增资预约网免费建站流程
  • js图片展示网站网站不用工具开发建设
  • 网络课程网站建设小程序注册之后怎么开发
  • 免费网站免费雄安网站制作多少钱
  • 做外贸网站特色东营哪里有做网络推广的
  • asp网站检查商业网点消防规范
  • 网站建设公司介绍ppt做商城的网站程序
  • 杭州市建设职业中心网站软文撰写案例
  • 如何自己开发一个网站网站开发课题背景
  • 磁力网站怎么做的郑州的网络科技有限公司
  • ps做网站大小尺寸怎样设计公司logo
  • 直接做网站的软件网页图片加载慢
  • 保健品网站源代码国家企业公示信息系统(全国)官网
  • 佛山网站建设企业网站建设项目书
  • 大学生网站规划建设比较公司网站与营销网站的不同
  • 网站开发设计需要什么证书清风WordPress
  • 第一免费营销型网站网站制作好后 怎样上线
  • 网站非法收录用户信息刚刚合肥最新通告
  • 网站开发专业的建设设想软文写作平台发稿
  • 企业网站网页设计有哪些wordpress 分类做导航栏
  • 学做网站好吗百度快速seo
  • 培训网站建设的背景做百度网站电话号码