• 【LeetCode 热题 HOT 100】1、两数之和


    1. 两数之和

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

    你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。

    你可以按任意顺序返回答案。

    示例 1:

    输入:nums = [2,7,11,15], target = 9
    输出:[0,1]
    解释:因为 nums[0] + nums[1] ==9 ,返回 [0, 1] 。

    示例 2:

    输入:nums = [3,2,4], target = 6
    输出:[1,2]

    示例 3:

    输入:nums = [3,3], target = 6
    输出:[0,1]

    提示:

    • 2 <= nums.length <= 104
    • -109 <= nums[i] <= 109
    • -109 <= target <= 109
    • 只会存在一个有效答案

    思路1:第一次做的时候只会暴力法,双重for循环遍历就完事了!奥利给

    class Solution {
        public int[] twoSum(int[] nums, int target) {
            for (int i = 0; i < nums.length - 1; i++){
                for (int j = i + 1; j < nums.length; j++){
                    if (nums[i] + nums[j] == target){
                        return new int[]{i, j};
                    }
                }
            }
            return new int[]{-1};
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    思路2:看了官方的第二种解法,确实很巧妙,使用HashMap来存储第一次遍历的元素,map的containsKey方法能够快速寻找数组中是否存在目标元素,使得原来的两次for循环降低到一次for循环,时间复杂度降低到从 O(N)降低到 O(1)。

    class Solution {
        public int[] twoSum(int[] nums, int target) {
            Map<Integer, Integer> map = new HashMap<>();
            for (int i = 0; i < nums.length; i++){
                // 判断map中是否存在key
                if (map.containsKey(target - nums[i])){
                    return new int[]{map.get(target - nums[i]), i};
                }
                map.put(nums[i], i);
            }
            return new int[]{-1};
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
  • 相关阅读:
    .NET周刊【10月第1期 2023-10-01】
    Java继承中的属性名相同但是类型不同的情况
    互联网性能和可用性优化CDN和DNS
    FreeRTOS之列表
    【C++初阶】C++入门(上)
    延迟任务多种实现姿势--上
    为什么要选择AWS?AWS的优势有哪些?
    mac搭建redis集群
    创建系统还原点及恢复
    i.MX8M Plus核心板、开发板编解码性能测试
  • 原文地址:https://blog.csdn.net/qq_42804736/article/details/125407820