#1_两数之和

作者: FiveZM | 来源:发表于2018-06-04 09:11 被阅读0次

    /*
    给定一个整数数组和一个目标值,找出数组中和为目标值的两个数。

    你可以假设每个输入只对应一种答案,且同样的元素不能被重复利用。

    示例:

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

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

    package leetCode;
    
    import java.util.HashMap;
    import java.util.Map;
    
    
    public class A_1_twoSum {
    
        public static void main(String[] args) {
            int[] nums = {2,7,11,15};
            int target = 9;
            int[] results = twoSum(nums,target);
            for(int i=0;i<results.length;i++) {
                System.out.print(i==0?"["+results[i]:","+results[i]);
            }System.out.println("]");
        }
        
    
        private static int[] twoSum(int[] nums, int target) {
            Map<Integer,Integer> map = new HashMap<>();
            for(int i=0;i<nums.length;i++) {
                int result = target - nums[i];
                if(map.containsKey(result) && map.get(result)!=i) {
                    return new int[] {map.get(result),i};
                }
                map.put(nums[i], i);
            }
            throw new IllegalArgumentException("NO TWO SUM SOLUTION");
        }
        
    }
    

    learn via https://leetcode-cn.com/articles/two-sum/

    相关文章

      网友评论

        本文标题:#1_两数之和

        本文链接:https://www.haomeiwen.com/subject/epkesftx.html