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

leeCode hot 100 !!!持续更新中

1.两数之和

给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target  的那 两个 整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案,并且你不能使用两次相同的元素。

你可以按任意顺序返回答案。

示例 1:

输入:nums = [2,7,11,15], target = 9
输出:[0,1]
解释:因为 nums[0] + nums[1] == 9 ,返回 [0, 1] 。

示例 2:

输入:nums = [3,2,4], target = 6
输出:[1,2]

示例 3:

输入:nums = [3,3], target = 6
输出:[0,1]

提示:

  • 2 <= nums.length <= 104
  • -109 <= nums[i] <= 109
  • -109 <= target <= 109

拿到这道题目,思路是,将数组中所有的数值的下标作为key,数值作为value,存进hashmap,然后遍历数组,用target减去遍历到的数值得到差值,然后看在hashmap中是否存在这个差值且不等于当前遍历到的数值,如果有返回i和map的key。

hashmap的定义有点忘了先复习一下,,,

代码如下:

class Solution {public int[] twoSum(int[] nums, int target) {HashMap<Integer,Integer> map = new HashMap<>();int [] ans = new int[2];for(int i= 0;i < nums.length;i ++){map.put( nums[i],i);}for(int i = 0;i < nums.length;i ++){int a = target - nums[i];if(map.containsKey(a) && i != map.get(a)){ans[0] = i;ans[1] = map.get(a);}}return ans;}
}

总结:1.记住HashMap的定义和用法比如put和containsKey和get。

           2.一般把要获得值设置为value,比如上面这题就把数值下标设置为value。

2.字母异位词分组

给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。

示例 1:

输入: strs = ["eat", "tea", "tan", "ate", "nat", "bat"]

输出: [["bat"],["nat","tan"],["ate","eat","tea"]]

解释:

  • 在 strs 中没有字符串可以通过重新排列来形成 "bat"
  • 字符串 "nat" 和 "tan" 是字母异位词,因为它们可以重新排列以形成彼此。
  • 字符串 "ate" ,"eat" 和 "tea" 是字母异位词,因为它们可以重新排列以形成彼此。

示例 2:

输入: strs = [""]

输出: [[""]]

示例 3:

输入: strs = ["a"]

输出: [["a"]]

提示:

  • 1 <= strs.length <= 104
  • 0 <= strs[i].length <= 100
  • strs[i] 仅包含小写字母

拿到这道题感觉是用hash但是不太会写,看下题解再写把,,,

思路:是将拿到的每个小字符串进行排序,先将遍历到的字符串转化为字符数组,再对字符数组进行排序,排序一样那就说明这两个字符串是字母异位,然后再用hashmap存储这个二维字符串数组。

class Solution {public List<List<String>> groupAnagrams(String[] strs) {//创建一个哈希表,用于存储排序后的字符串及其对应字母异位词列表HashMap<String ,List<String>> map = new HashMap<>();//遍历输入的字符串数组for(int i = 0;i < strs.length;i ++){//将字符串转化为字符数组,因为在java中字符串是无法改变的所以需要转换为字符数组才能进行后面的排序char [] array = strs[i].toCharArray();//对字符数组进行排序Arrays.sort(array);//将排序后的字符数组转化为字符串,作为哈希表的健String key = new String(array);//如果哈希表不包含该建,则创建一个新的列表并将其与该建关联if(!map.containsKey(key)){map.put(key,new ArrayList<>());}//将当前字符串加入到对应的列表中map.get(key).add(strs[i]);}return new ArrayList<>(map.values());}
}

3.最长连续序列

给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。

请你设计并实现时间复杂度为 O(n) 的算法解决此问题。

示例 1:

输入:nums = [100,4,200,1,3,2]
输出:4
解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。

示例 2:

输入:nums = [0,3,7,2,5,8,4,6,0,1]
输出:9

示例 3:

输入:nums = [1,0,1,2]
输出:3

提示:

  • 0 <= nums.length <= 105
  • -109 <= nums[i] <= 109

看到这道题依然没什么思路,,,

思路:先将数组存在set中去重,然后遍历set里的每个元素,先通过查找这个元素减一是否存在在集合中来看它是否是序列的开头,如果是那么就用while循环通过查找它后面的元素来看这个序列长度,然后更新最长的序列长度即可。如果不是序列的开头直接把他跳过就行,对应代码中就是max的更新在if条件内。

注:因为这道题涉及到遍历set集合所以for循环可以用增强for循环。

class Solution {public int longestConsecutive(int[] nums) {Set<Integer> set = new HashSet<>();for(int i = 0;i < nums.length;i ++){set.add(nums[i]);}int max = 0;for(int num : set){if(!set.contains(num - 1)){int ll = 1;while(set.contains(num + 1)){num+= 1;ll ++;}max = Math.max(max,ll);}}return max;}
}

http://www.dtcms.com/a/578115.html

相关文章:

  • 想学网站建设选计算机应用技术还是计算机网络技术哪个专业啊网站建设工单系统护语
  • WordPress魔方格子做网站优化费用
  • 高校实验室建设方案解析:从规划到落地的全流程指南
  • javaweb前端基础
  • 从“会烧开水”到“知其所以然”:扩散模型文生图的理论基石
  • SQL注入之二次、加解密、DNS等注入
  • 网站开发速成班免费可商用的图片素材网站
  • 打破智能家居生态壁垒,乐鑫一站式Matter解决方案实现无缝互联
  • 用 CdcUp CLI 一键搭好 Flink CDC 演练环境
  • 【云运维】zabbix管理(续)
  • centos安装ES
  • 网站子目录是什么南通制作公司网站
  • 怎样设计网站或网页怎么样在百度做网站
  • SELinux 布尔值详解:灵活调整安全策略的开关
  • 李宏毅机器学习笔记41
  • 1-GGML:看ctx是个什么东西
  • 【Java SE 基础学习打卡】02 计算机硬件与软件
  • SDIO(Secure Digital Input Output,安全数字输入输出)
  • wordpress批量下载外链图片长春网站推广优化公司
  • 在 Ubuntu 上安装 Ollama 并通过 Open WebUI 运行本地大语言模型
  • 用Python来学微积分34-定积分的基本性质及其应用
  • 如何做网站代码荥阳市城乡建设规划网站
  • Jmeter+ant+Jenkins 接口自动化框架-让jmeter脚本自己跑起来
  • 宝安区住房和建设局网站河南做网站多少钱
  • Java集合框架:深入理解List与Set及其实现类
  • 前端工程师职业规划与转型指南
  • 网站建设管理情况的通报国外工业产品设计网站
  • EventOS:面向MCU的事件驱动框架
  • 视频直播点播平台EasyDSS:打造高品质赛事直播的全链路解决方案
  • 广州网站制作哪家全面万达做的电商网站