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

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返回
    }
}
相关推荐
nice_lcj5201 分钟前
排序(4)-归并排序专题——归并排序的分治美学
java·数据结构·算法·排序算法
洛水水16 分钟前
【力扣100题】83.最小栈
算法·leetcode·职场和发展
无忧.芙桃18 分钟前
数据结构之栈
c语言·开发语言·数据结构
nice_lcj52025 分钟前
排序(3)-第三篇:交换排序专题——从冒泡排序到快速排序的效率飞跃
java·数据结构·算法·排序算法
ywl47081208730 分钟前
数据结构之链表反转算法
数据结构·算法·链表
牧子川31 分钟前
019-JSON-Schema-自动生成
算法·大模型·格式化输出·tools
lhjcsubupt42 分钟前
第二十二篇 从随机过程到IMU噪声模型
算法·机器学习·概率论
神仙别闹1 小时前
基于C语言处理机调度算法的实现
服务器·c语言·算法
Brilliantwxx1 小时前
【算法从零到千】【16-23】 二分算法
数据结构·算法
8Qi87 小时前
回文子串(Palindromic Substrings)—— 题解
算法·leetcode·职场和发展·动态规划