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

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)

nums[0] = 2

temp = target - nums[0] = 9 - 2 = 7

检查 map.containsKey(7) → false

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

第二次遍历 (i=1)

nums[1] = 7

temp = target - nums[1] = 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返回
    }
}
相关推荐
2401_8384725111 小时前
C++模拟器开发实践
开发语言·c++·算法
s1hiyu11 小时前
实时控制系统验证
开发语言·c++·算法
daad77711 小时前
V4L2_mipi-csi
算法
2301_7657031411 小时前
C++代码复杂度控制
开发语言·c++·算法
m0_7088309611 小时前
C++中的享元模式实战
开发语言·c++·算法
naruto_lnq12 小时前
分布式计算C++库
开发语言·c++·算法
m0_7066532312 小时前
模板编译期排序算法
开发语言·c++·算法
历程里程碑12 小时前
Linxu14 进程一
linux·c语言·开发语言·数据结构·c++·笔记·算法
木井巳12 小时前
【递归算法】验证二叉搜索树
java·算法·leetcode·深度优先·剪枝
m0_5613596712 小时前
嵌入式C++加密库
开发语言·c++·算法