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 <= 1040 <= strs[i].length <= 100strs[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;}
}