代码随想录之哈希表(力扣题号)
创始人
2024-05-30 14:22:27
0

242. 有效的字母异位词

在这里插入图片描述
直接用数组模拟哈希表
只有小写字母,开26的数组就可以了

class Solution {public boolean isAnagram(String s, String t) {//24-28int[] hash = new int[26];Arrays.fill(hash,0);for(int i=0;ihash[s.charAt(i)-'a']++;}for(int i=0;ihash[t.charAt(i)-'a']--;}for(int i=0;iif(hash[i]!=0) return false;}return true;}
}

49. 字母异位词分组

在这里插入图片描述
思路也是用hashmap,但是java的操作没有很熟练,遇到很多问题,最后看了题解还是没能一次性写完,中间还看了两次,之后需要再练习几次

class Solution {public List> groupAnagrams(String[] strs) {//01-29Map> mp= new HashMap<>();      for(int i=0;ichar[] arr = strs[i].toCharArray();Arrays.sort(arr);String key = new String(arr);List list = mp.getOrDefault(key,new ArrayList());list.add(strs[i]);mp.put(key,list);}return new ArrayList>(mp.values());}
}

时间复杂度:
O(nklogk),其中 n 是 strs 中的字符串的数量,k 是 strs 中的字符串的的最大长度。需要遍历 n 个字符串,对于每个字符串,需要 O(klogk) 的时间进行排序以及 O(1) 的时间更新哈希表,因此总时间复杂度是 O(nklogk)。

空间复杂度:O(nk),其中 n 是 strs中的字符串的数量,k 是 strs 中的字符串的的最大长度。需要用哈希表存储全部字符串。

15 三数之和

在这里插入图片描述
在这里插入图片描述

这题和之前牛客做过的一样,还是一样的思路:在两数之和的基础上遍历,然后用set去重,这题不要求输出结果也排序。但是这题的数据范围更大,按照之前的写法会超时,所以加了个排序,然后如果是重复的数字就跳过遍历。

class Solution {public List> threeSum(int[] nums) {//57-40Arrays.sort(nums);List> res= new ArrayList>();List> ress= new ArrayList>();for(int i=0;iint target = -nums[i];if(i>0&&nums[i]==nums[i-1]) continue;//跳过遍历,否则会超时Map mp = new HashMap<>();for(int j = i+1;jif(mp.containsKey(nums[j])){List row = new ArrayList<>();row.add(nums[i]);row.add(target-nums[j]);row.add(nums[j]);row.sort((a,b)->a-b);  res.add(row);}mp.put(target-nums[j],j);              }}Set> s = new HashSet>();for(int i=0;is.add(res.get(i));}for( List r:s){ress.add(r);}return ress;}
}

但是这样还是三重循环,时间复杂度还是N的三次方。
可以继续改进:当a+b+c=0的时候,第二层b’>b,要让条件满足的c‘一定

class Solution {public List> threeSum(int[] nums) {//57-40Arrays.sort(nums);List> res= new ArrayList>();List> ress= new ArrayList>();for(int i=0;iint target = -nums[i];if(i>0&&nums[i]==nums[i-1]) continue;Map mp = new HashMap<>();int left = i+1;int right = nums.length-1;while(leftif(nums[left]+nums[right]target) right--;else{while(left + 1 < right && nums[left] == nums[left + 1])//去重left++;while(right - 1 > left && nums[right] == nums[right - 1])//去重right--;List row = new ArrayList<>();row.add(nums[i]);row.add(nums[left]);row.add(nums[right]);res.add(row);left++;right--;}}                         }return res;}
}

18 四数之和

在这里插入图片描述
在这里插入图片描述
和三数之和的思路一样,就是多了一层循环,但是四数有一个坑点在于用int会溢出,要转换成long

class Solution {public List> fourSum(int[] nums, int target) {//47-04List> res = new ArrayList>();Arrays.sort(nums);for(int i=0;iif(i>0&&nums[i]==nums[i-1]) continue;for(int j = i+1;jif(j>i+1&&nums[j]==nums[j-1]) continue;int left = j+1;int right = nums.length-1;while(left//注意要转换成long,否则会溢出long sum = (long)nums[i]+(long)nums[j]+(long)nums[left]+(long)nums[right];if(sum>target) right--;else if(sumList tmp = new ArrayList();tmp.add(nums[i]);tmp.add(nums[j]);tmp.add(nums[left]);tmp.add(nums[right]);res.add(tmp);//可以用一句解决//res.add(Arrays.asList(nums[i], nums[j], nums[left], nums[right]));while(left

相关内容

热门资讯

安卓系统曝光作用原理,揭秘安卓... 你知道吗?最近安卓系统又曝光了一些新动向,这让我这个科技爱好者兴奋不已。今天,就让我带你一探究竟,揭...
安卓盲区监测系统有哪些,安全驾... 你有没有想过,开车的时候,突然一个盲区里的“小家伙”冒了出来,那感觉简直就像是从天而降的惊吓!别担心...
安卓还是苹果系统好用吗,谁更胜... 说到手机系统,安卓和苹果的较量可是从手机诞生之初就开始了。你有没有想过,到底哪个系统更适合你呢?今天...
设置安卓系统的默认相机,功能与... 你有没有发现,每次打开手机拍照,相机界面总是那个老样子?是不是有点审美疲劳了呢?别急,今天就来教你怎...
抖音支持的安卓系统,支持版本全... 你有没有发现,最近抖音可是越来越火了呢?不管是在地铁里、公交车上,还是在家里,总能看到大家刷着抖音,...
安卓系统怎么把文件导出,例如使... 你是不是也和我一样,手机里存了好多宝贝文件,想分享给朋友或者备份到电脑上呢?别急,今天就来教你怎么把...
复印机用安卓系统 你有没有想过,那些默默无闻的复印机竟然也能玩转高科技?没错,就是那个每天帮你打印、复印、扫描的小家伙...
安卓9.0系统怎么安装Busy... 你有没有想过给你的安卓手机来个系统升级,让它焕发新生呢?今天,我就来手把手教你如何安装安卓9.0系统...
安卓12系统安装微信,体验流畅... 你有没有发现,最近你的安卓手机更新到了安卓12系统?是不是有点小激动呢?不过,别急着高兴,因为更新了...
ps安卓系统下载官网,一站式获... 你有没有想过,手机里的安卓系统其实就像是一个神奇的魔法世界?想要探索这个世界的奥秘,第一步就是要找到...
热卖推荐双系统安卓平板,畅享多... 你有没有想过,在这个信息爆炸的时代,拥有一款既能满足工作需求,又能畅享娱乐的平板电脑是多么重要的事情...
换了安卓又想换苹果系统,系统切... 你有没有过这样的经历?手机用着用着,突然就腻了,想要换换口味?这不,我就刚从安卓阵营跳到了苹果的怀抱...
安卓系统比ios容量,iOS系... 你有没有想过,为什么你的安卓手机总是比iOS手机看起来能装下更多的东西呢?这背后其实有着不少门道呢!...
安卓系统如何有两个系统,安卓设... 你有没有想过,你的安卓手机里竟然可以藏着一个秘密世界?没错,就是可以同时拥有两个系统!这听起来是不是...
安卓系统崩溃进不去,深度解析故... 手机突然间罢工了,屏幕上黑漆漆的,安卓系统崩溃了,你心里是不是慌得一批?别急,今天就来给你详细说说安...
苹果系统游戏怎么变安卓,轻松实... 你有没有想过,那些在苹果系统上玩得如痴如醉的游戏,怎么就能在安卓系统上继续畅玩呢?是不是觉得这中间隔...
xp系统读取安卓手机,数据同步... 你有没有想过,你的XP系统竟然能读取安卓手机的数据呢?这听起来是不是有点神奇?别急,今天就来带你一探...
安卓系统用的流量,揭秘手机流量... 你有没有发现,手机里的安卓系统用流量那叫一个“疯狂”?有时候,明明没做什么大动作,流量就“嗖”的一下...
入门安卓机32位系统,轻松驾驭... 你有没有想过,拥有一台入门级的安卓手机,却因为32位系统而头疼不已?别急,今天就来给你详细解析一下这...
安卓系统怎么下对峙2,操作指南... 你有没有想过,在安卓系统上下载一款叫做“对峙2”的游戏会是怎样的体验呢?这款游戏在众多玩家中可是小有...