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)

相关推荐
金融小师妹1 小时前
基于LSTM-GARCH混合模型的“获利了结”量化解析:黄金单日1.27%跌幅的技术性归因
大数据·人工智能·算法
不良手残2 小时前
Java实现10大经典排序算法
数据结构·算法·排序算法
是紫焅呢2 小时前
I排序算法.go
开发语言·后端·算法·golang·排序算法·学习方法·visual studio code
辉辉还没睡3 小时前
Lora训练
人工智能·算法·机器学习
日月星宿~3 小时前
【redis】数据结构及操作命令
数据结构·数据库·redis
lyx 弈心3 小时前
数据结构 双向链表与双向循环链表 6.17
数据结构·链表
电院大学僧5 小时前
初学python的我开始Leetcode题10-2
python·算法·leetcode
码破苍穹ovo6 小时前
二分查找----1.搜索插入位置
数据结构·算法
烨然若神人~7 小时前
算法第38天|322.零钱兑换\139. 单词拆分
算法
sukalot7 小时前
window显示驱动开发—输出合并器阶段
驱动开发·算法