LeetCode热题100(一)—— 1.两数之和

LeetCode热题100(一)------ 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
        只会存在一个有效答案
进阶:你可以想出一个时间复杂度小于 O(n2) 的算法吗?

代码实现

java 复制代码
// 思路一:双循环
class Solution {
    public int[] twoSum(int[] nums, int target) {
        int[] result = new int[2];
        for(int i=0; i<nums.length; i++)
            for(int j=i+1; j<nums.length; j++){
                if((nums[i]+nums[j])==target){
                    result[0] = i;
                    result[1] = j;
                }
            }
        return result;
    }
}
// 思路二:哈希表
class Solution {
    public int[] twoSum(int[] nums, int target) {
        Map<Integer, Integer> map = new HashMap<>();
        for (int i = 0; i < nums.length; i++) {
            int num = target - nums[i];
            if (map.containsKey(num)) {
                return new int[]{i, map.get(num)};
            }
            map.put(nums[i], i);
        }
        return null;
    }
}

思路解析

  1. 输入:整数数组和目标值int[] nums, int target
  2. 输出:两个元素下标 [i, j]nums[i] + nums[j] = target
  3. 思路一:双层循环
    • 时间复杂度: O ( n 2 ) O(n^2) O(n2)
    • 空间复杂度: O ( 1 ) O(1) O(1)
  4. 思路二:哈希表
    • 时间复杂度: O ( n ) O(n) O(n)
    • 空间复杂度: O ( n ) O(n) O(n)

相关推荐
一直不明飞行几秒前
C++:string,写法s.find(‘@‘) != s.end()是否有问题
开发语言·c++·算法
Proxy_ZZ012 分钟前
打造自己的信道编码工具箱——Turbo、LDPC、极化码三合一
c语言·算法·信息与通信
wayz1114 分钟前
21天机器学习核心算法学习计划(量化方向)
学习·算法·机器学习
qq. 280403398414 分钟前
数据结构引论
前端·数据结构
穿条秋裤到处跑15 分钟前
每日一道leetcode(2026.04.09):区间乘法查询后的异或 II
算法·leetcode
超级大只老咪22 分钟前
一维度前缀和解题通用模板(java)
java·开发语言·算法
weixin_5134499627 分钟前
walk_these_ways项目学习记录第十篇(通过行为多样性 (MoB) 实现地形泛化)--从仿真到部署
人工智能·学习·算法
历程里程碑29 分钟前
1 . Git本地操作:版本控制 跨平台协作 仓库核心
java·开发语言·数据结构·c++·git·gitee·github
小欣加油32 分钟前
leetcode 42 接雨水
c++·算法·leetcode·职场和发展
tankeven38 分钟前
动态规划专题(14):石子合并问题(未完待续)
c++·算法·动态规划