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") ;
        }
    }
  • 相关阅读:
    主线程——main线程
    进程和线程概念及原理
    抓取网贷之家的数据爬虫
    感知哈希算法的java实现
    最短路径—Dijkstra算法和Floyd算法
    关于图像特征提取
    hive学习之WordCount单词统计
    pig、hive以及hbase的作用
    zookeeper入门知识
    hadoop文件系统浅析
  • 原文地址:https://www.cnblogs.com/manru75/p/12920242.html
Copyright © 2011-2022 走看看