LeetCode力扣每日一题(Java):1、两数之和

一、题目

二、解题思路

方法一:暴力枚举

这是最容易想到的一种方法,本质就是二重循环遍历数组,话不多说直接上代码

java 复制代码
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[]{};
    }

虽说这种方法简单,但在解题过程中我还是感到自己java基础的不牢。比如我一开始if中的代码是这样写的:

int\[\] arr = { i,j };

return arr;

后来发现可以直接return new int\[\]{i, j};

而且我一开始没有在for循环外面写return new int\[\]{}; 导致代码编译出错,报错提示是:缺少返回值

看来要打算法竞赛我还是任重而道远的

方法二:哈希表

这是一种我从没接触过的方法,而且数据结构基本上忘光了(偷笑)

所以我们首先回顾一下什么是哈希表:简单来说就是通过hash函数将关键字的值映射到对应的存储地址中。常用的哈希函数方法有直接定址法、除留余数法等,定址时还涉及到哈希冲突的解决。

再看力扣官方题解

注意到方法一的时间复杂度较高的原因是寻找 target - x 的时间复杂度过高。因此,我们需要一种更优秀的方法,能够快速寻找数组中是否存在目标元素。如果存在,我们需要找出它的索引。

使用哈希表,可以将寻找 target - x 的时间复杂度降低到从 O(N)降低到 O(1)。

这样我们创建一个哈希表,对于每一个 x,我们首先查询哈希表中是否存在 target - x,然后将 x 插入到哈希表中,即可保证不会让 x 和自己匹配。

作者:力扣官方题解

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

来源:力扣(LeetCode)

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

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(target - nums[i])) {
                return new int[]{hashtable.get(target - nums[i]), i};
            }
            hashtable.put(nums[i], i);
        }
        return new int[0];
    }
}

作者:力扣官方题解
链接:https://leetcode.cn/problems/two-sum/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

好家伙,你一波操作猛如虎,而我愣是没看懂......好吧,看来确实没学扎实,只能一个一个概念去学了

此处省略很多时间,太多要学的啦

了解完各个概念之后,我们给这段代码打上详细的注释

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) {
            // 计算目标值与当前元素的差值
            int complement = target - nums[i];
            
            // 如果哈希表中存在差值,则返回结果
            if (hashtable.containsKey(complement)) {
                // 返回两个元素的索引
                return new int[]{hashtable.get(complement), i};
            }
            
            // 将当前元素和索引加入哈希表
            hashtable.put(nums[i], i);
        }
        
        // 如果没有找到符合条件的两个元素,返回空数组
        return new int[0];
    }
}
相关推荐
Raink老师14 小时前
【AI面试临阵磨枪-79】实时数据 RAG:订单、商家、物流、天气、动态库存
人工智能·面试·职场和发展
Cosolar14 小时前
Chroma向量库面试学习指南
数据库·人工智能·面试·职场和发展·数据库架构
kkeeper~15 小时前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
wabs66616 小时前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_8769641317 小时前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
嗝o゚17 小时前
CANN GE 算子融合——融合算法与调度策略
算法·昇腾·cann·ge
小江的记录本17 小时前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试
Ulyanov19 小时前
用声明式语法重新定义Python桌面UI:QML+PySide6现代开发入门(一)
开发语言·python·算法·ui·系统仿真·雷达电子对抗仿真
数据科学小丫19 小时前
特征工程处理
人工智能·算法·机器学习
秦明月1319 小时前
电芯装配测试线安全回路设计实战
经验分享·其他·职场和发展·创业创新·学习方法