LeetCode:1. 两数之和

简介

题目链接:https://leetcode.cn/problems/two-sum/description/

解决方式:数组 + 哈希表、暴力枚举

这是作者学习众多大神的思路进行解题的步骤,很推荐大家解题的时候去看看题解里面大佬们的思路、想法!

暴力枚举

解题思路:双重循环挨个挨个匹配,匹配上了就返回。

java 复制代码
class Solution {
    public int[] twoSum(int[] nums, int target) {
        int n = nums.length;
        for(int i = 0; i < n; i ++){
            for(int j = i + 1; j < n; j ++){
                if(nums[i] + nums[j] == target){
                    return new int[]{i,j};
                }
            }
        }
        return new int[0];
    }
}

哈希表

思路:一次迭代,借助哈希表存储迭代的信息。key 是当前元素在之后数组中的另一个合数,借助哈希表的快速判断能力,快速查询是否存在两数之和等与 target。

java 复制代码
class Solution {
    public int[] twoSum(int[] nums, int target) {
        // 哈希表,存储遍历信息
        Map<Integer,Integer> hashtable = new HashMap<Integer,Integer>();
        for (int i = 0; i < nums.length; i ++){
            if(hashtable.containsKey(nums[i])){
                // 返回结果
                return new int[]{hashtable.get(nums[i]), i};
            }
            // key 为当前元素的目标元素(当前元素 + 目标元素 = target)
            // value 为当前元素的索引
            // 后续迭代中,如果迭代元素就等于 key 说明找到了两束子和等于 target
            hashtable.put(target - nums[i], i);
        }
        return new int[0];
    }
}
相关推荐
菜菜的顾清寒21 小时前
Leetcode (18) 力扣100 矩阵置零
算法
董董灿是个攻城狮21 小时前
5分钟搞懂微调的能力退化问题
算法
穿条秋裤到处跑21 小时前
每日一道leetcode(2026.04.19):下标对中的最大距离
算法·leetcode·职场和发展
Sag_ever1 天前
时间复杂度与空间复杂度超详细入门讲解
算法
念越1 天前
算法每日一题 Day03|快慢双指针解决快乐树问题
算法·力扣
ZPC82101 天前
MoveGroup 规划轨迹 → 直接交给 MoveIt2 Servo 执行
人工智能·算法·计算机视觉·机器人
️是781 天前
信息奥赛一本通—编程启蒙(3373:练64.2 图像旋转翻转变换)
数据结构·c++·算法
Bat U1 天前
Java高阶数据结构|AVL树
数据结构
Xiu Yan1 天前
Java 转 C++ 系列:STL容器之list
java·开发语言·数据结构·c++·stl·list·visual studio
木子墨5161 天前
LeetCode 热题 100 精讲 | 计算几何篇:点积叉积 · 线段相交 · 凸包 · 多边形面积
c++·算法·leetcode·职场和发展·动态规划