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;
    }
}
相关推荐
lemontree19452 小时前
CRC8算法通用版本
算法
热爱生活的猴子2 小时前
算法322. 零钱兑换
算法
剪一朵云爱着2 小时前
力扣1539. 第 k 个缺失的正整数
算法·leetcode
摸鱼仙人~2 小时前
针对编程面试和算法题的基础书籍
算法·面试·职场和发展
京东零售技术2 小时前
一款AB实验分析智能体是如何诞生的
算法
麦烤楽鸡翅2 小时前
【模板】二维前缀和 (牛客)
java·c++·算法·秋招·春招·二维前缀和·面试算法题
Jeff-Nolan3 小时前
数据结构(c++版):邻接表的实现
数据结构·链表
千弥霜3 小时前
codeforces1914 C~F
c语言·算法
wyiyiyi3 小时前
【数据结构+算法】进栈顺序推算、卡特兰数与逆波兰表达式
汇编·数据结构·笔记·算法