zoukankan      html  css  js  c++  java
  • 力扣----1. 两数之和(JavaScript, Java实现)

    题目描述:

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

    你可以假设每种输入只会对应一个答案。但是,数组中同一个元素不能使用两遍。

    示例:

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

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

    时间复杂度O(n)

    JavaScript实现

    /**
     * @param {number[]} nums
     * @param {number} target
     * @return {number[]}
     */
    var twoSum = function(nums, target) {
        let tempMap= new Map()
        for(let i = 0; i < nums.length; i++){
            let numOther = target - nums[i]
            if (tempMap.has(numOther)) {
              return [tempMap.get(numOther), i]
            }
            tempMap.set(nums[i], i)
        }
    };

    Java实现

    class Solution {
        public int[] twoSum(int[] nums, int target) {
            Map<Integer, Integer> tempMap = new HashMap<>();
            for(int i=0; i<nums.length;i++){
                int numOther = target - nums[i];
                if(tempMap.containsKey(numOther)){
                    return new int[] {tempMap.get(target- nums[i]), i};
                }
                tempMap.put(nums[i], i);           
            }
            throw new IllegalArgumentException("none") ;
        }
    }
  • 相关阅读:
    一条SQL的执行流程
    LinkedList源码解析
    MinorGC前检查
    AbstractList源码分析
    JVM常用命令
    CountDownLatch源码解析
    ReentrantLock源码解析
    HTTPS简单介绍
    工厂方法模式
    观察者模式
  • 原文地址:https://www.cnblogs.com/manru75/p/12920242.html
Copyright © 2011-2022 走看看