LeetCode 1. 两数之和 Java版

1. 两数之和

给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。

你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。

示例:

给定 nums = [2, 7, 11, 15], target = 9

因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]

用哈希思想来做就是最好的解答。
如果一个target - num[i] 存在那么就返回那个数字对应的下标和当前元素的下标。

import java.util.HashMap;
import java.util.Map;

/**
 * @author PineappleSnow
 * @version 1.0
 * @date 2020/3/30 21:37
 * 1.两数之和
 */
public class $1_TwoSum {
    public int[] twoSum(int[] nums, int target) {
        Map<Integer,Integer> map=new HashMap<Integer, Integer>();
        int[] res=new int[2];
        for(int i = 0, len = nums.length; len > i; i++){
            if(map.containsKey(target-nums[i])){
                return new int[]{map.get(target-nums[i]),i};
            }else{
                map.put(nums[i],i);
            }
        }
        return res;
    }
}

发布了54 篇原创文章 · 获赞 28 · 访问量 7275

猜你喜欢

转载自blog.csdn.net/jiangkun0331/article/details/105210773