两数之和和字母异位词分组

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
  • 只会存在一个有效答案
java 复制代码
class Solution {
    public int[] twoSum(int[] nums, int target) {
        //判断一下是否为空,如果为空则返回空数组
        if (nums==null || nums.length==0){
            return new int[]{};
        }
        //创建一个map
        Map<Integer,Integer> map=new HashMap<>();
        for (int i = 0; i < nums.length; i++){
            // 获取当前值
            int temp=target-nums[i];
            if (map.containsKey(temp)){
                return new int[]{map.get(temp), i};
            }else {
                // 如果没有将当前值放入map中
                map.put(nums[i],i);
            }
        }
        // 如果没有找到则返回空数组
        return new int[]{};
    }
    
    }

初始状态

数组 nums = 2,7,11,15

目标值 target = 9

哈希表 map 为空

第一次遍历 (i=0)

nums0 = 2

temp = target - nums0 = 9 - 2 = 7

检查 map.containsKey(7) → false

执行 map.put(2, 0) → 存储 {2: 0}

第二次遍历 (i=1)

nums1 = 7

temp = target - nums1 = 9 - 7 = 2

检查 map.containsKey(2) → true (找到了!)

返回 new int\[\]{map.get(2), 1} → 0, 1

49. 字母异位词分组

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

示例 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] 仅包含小写字母
java 复制代码
class Solution {
    // 主方法:字母异位词分组
    public List<List<String>> groupAnagrams(String[] strs) {
        // 创建HashMap存储分组结果,key为排序后的字符串,value为该组的所有字符串列表
        HashMap<String, List<String>> map = new HashMap<>();

        // 遍历输入的字符串数组
        for (String str : strs) {
            // 1. 将字符串转为字符数组并排序
            char[] chars = str.toCharArray();  // 将当前字符串转换为字符数组
            Arrays.sort(chars);                // 对字符数组进行排序,使异位词有相同的排序结果
            String key = new String(chars);    // 将排序后的字符数组转回字符串作为key

            // 2. 检查key是否已存在
            if (!map.containsKey(key)) {       // 如果map中不存在这个key
                // key不存在,创建新的空列表
                map.put(key, new ArrayList<>()); // 为这个key创建一个新的ArrayList
            }
            // 3. 将当前字符串添加到对应列表
            map.get(key).add(str);             // 获取key对应的列表,并将当前字符串添加进去
        }

        // 返回所有分组结果
        return new ArrayList<>(map.values());  // 将map中所有value(即字符串列表)组成一个新的ArrayList返回
    }
}
相关推荐
vibecoding日记2 小时前
双非如何快速入职字节等大厂大模型?真实案例分析:推理优化和投机解码
算法·求职·大模型工程师
yszaygr21384 小时前
Verilog参数化游程编码RLE模块
算法
望易4 小时前
刚设计的大模型架构-双域耦合认知框架
算法·架构
复杂网络8 小时前
多个 Claude Code 与多个 Codex 协同工作:设计与实现方案
算法
HjhIron1 天前
面试常客:字符串算法从入门到进阶
算法·面试
吴佳浩1 天前
DeepSeek DSpark:Confidence-Scheduled Speculative Decoding 技术解析
人工智能·算法·deepseek
触底反弹1 天前
🧠 搞懂 Token,才算真正入门大模型——从分词原理到 Embedding 语义实战
javascript·人工智能·算法
vivo互联网技术1 天前
ICLR 2026 | 基于后验采样的图像恢复方法LearnIR:人脸去阴影、去雾
人工智能·算法·aigc
浮生望1 天前
JS字符串与回文算法:从包装类到双指针的面试进阶之路
javascript·算法
黄敬峰1 天前
面试必刷:从JS底层包装类到双指针,彻底搞懂字符串与回文算法
算法