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];
    }
}
相关推荐
youngerwang1 小时前
【从搬运工到协处理器:网卡芯片架构、算法、验证与边缘演进深度剖析】
网络·算法·架构·芯片
想要成为糕糕手1 小时前
前端必修课:JavaScript 数组与数据结构底层逻辑全解析
javascript·数据结构·面试
KaMeidebaby1 小时前
卡梅德生物技术快报|纯化重组蛋白实操详解
人工智能·python·tcp/ip·算法·机器学习
手写码匠2 小时前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力3 小时前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试
lqqjuly3 小时前
MLA — 多头潜在注意力深度解析
深度学习·神经网络·算法
吴可可1233 小时前
SolidWorks草图转三维DWG技巧
算法
tyung3 小时前
Go 手写 Wait-Free SPSC 无界队列:无 CAS、无锁、泛型节点池
数据结构·后端·go
redaijufeng4 小时前
C++雾中风景7:闭包
c++·算法·风景
Chen_harmony4 小时前
一、数据结构概念和复杂度计算
数据结构