题解 | #两数之和#

两数之和

http://www.nowcoder.com/practice/20ef0972485e41019e39543e8e895b7f



public class Solution {
    /**
     * 题目描述:给出一个整型数组 numbers 和一个目标值 target,
     *          请在数组中找出两个加起来等于目标值的数的下标,返回的下标按升序排列。
*      解题思路:创建一个哈希表HashMap<Integer,Integer>,遍历数组;首先将目标值target减去
     *          当前遍历的数组值(numbers[i])=another,再从哈希表HashMap中查找是否存在key:another,
     *          如果存在,就存在两个数(another,i)相加为target。并创建一个长度为2的新数组arr,
     *          arr[0] = hashMap.get(another);arr[1] = i+1;
     * @param numbers int整型一维数组
     * @param target int整型
     * @return int整型一维数组
     */
    public int[] twoSum (int[] numbers, int target) {
        // write code here
        //创建一个哈希表
        HashMap<Integer,Integer> hashMap = new HashMap<>(numbers.length);
        int[] arr = new int[2];
        for (int i = 0; i < numbers.length; i++) {//遍历数组
            int another = target-numbers[i];//首先将目标值target减去当前遍历的数组值(numbers[i])=another,
            //再从哈希表HashMap中查找是否存在key:another,如果存在,就存在两个数(another,i)相加为target。
            if(hashMap.containsKey(another)){
                arr[0] = hashMap.get(another);
                arr[1] = i+1;
                return arr;  //返回结果,结束循环
            }else{
                hashMap.put(numbers[i],i+1);
            }
        }

        return null;
    }
}
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-07 12:04
毕业生招你惹你了,问一个发薪日来一句别看网上乱七八糟的你看哪个工作没有固定发薪日扭头就取消了面试就问了一句公司都是这个态度吗还搞上人身攻击了...
程序员小白条:呃呃呃,都还没面试,我都不会问这么细,何况通不通过,去不去都另说,你没实力和学历的话,在外面就这样,说实话没直接已读不回就不错了,浪费时间基本上
点赞 评论 收藏
分享
06-02 15:53
阳光学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务