给定一个整数数组 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]
给你一个字符串数组,请你将 字母异位词 组合在一起。可以按任意顺序返回结果列表。
示例 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]仅包含小写字母
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返回
}
}