【Java SE 题库】LeetCode 热题 100--->两数之和

🔥 博客主页🔥 :【 坊钰_CSDN博客

欢迎各位点赞👍 评论**✍收藏⭐**

目录

[1. 题目](#1. 题目)

[2. 解析](#2. 解析)

[2.1 判断两个数相加是否等于目标值](#2.1 判断两个数相加是否等于目标值)

[2.2 相等后,如何返回两个下标](#2.2 相等后,如何返回两个下标)

[3. 代码](#3. 代码)

[4. 小结](#4. 小结)


取于力扣-->LeetCode 热题 100 - 学习计划 - 力扣(LeetCode)全球极客挚爱的技术成长平台

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. 解析

这道题难度一般,只有两个难点

  • 怎么判断两个数相加等于目标值
  • 判断相等后,如何返回两个下标

2.1 判断两个数相加是否等于目标值

这种可以用快慢 "标识" 法,也就是用两个标识,起始位置分别指向数组的 0 下标,和 1 下标,并且在后面的标识始终比前面的标识大一位,这样就不会遇到两个标识指向同一位的情况

2.2 相等后,如何返回两个下标

这个问题难倒很多同学,想一想,两个下标是两个数,我们可以把它们存储倒数组中,然后在返回数组就可以了

3. 代码

java 复制代码
class Solution {

    public int[] twoSum(int[] nums, int target) {
        for(int i = 0; i < nums.length; i++) {     //前标识
            for(int j = i + 1; j < nums.length; j++) {   //后标识,始终大于前标识一位

                if(nums[i] + nums[j] == target) {  //判断是否相等
                    return new int[]{i, j};        //创建数组存储并返回
                }

            }
        }
        return new int[0];  //如果没有,则返回 0
    }

}

4. 小结

以上就是对该题的了解,具体还需宝子们去实践,如果觉得该博客对你有用的话,希望一键三连,点个关注不迷路,谢谢支持 !

相关推荐
不吃香菜5672 分钟前
cloudcode入门学习
java·windows·cloudcode
疯狂成瘾者2 分钟前
Java 常见 Map 对比总结:HashMap、LinkedHashMap、TreeMap、ConcurrentHashMap
java·开发语言·spring
XMYX-04 分钟前
16 - Go 协程(goroutine):从基础到实战
开发语言·golang
一只游鱼6 分钟前
langchain4j+redis+持久化存储记忆
java·redis·langchain4j
野生技术架构师10 分钟前
牛客网热门Java 面试题汇总,查漏补缺;多线程 +spring+JVM 调优 + 分布式 +redis+ 算法
java·jvm·spring
星幻元宇VR11 分钟前
VR互动平台|开启沉浸式体验新方式
科技·学习·安全·vr·虚拟现实
txxzjmzlh13 分钟前
Thread 类的基本用法
java·开发语言
machnerrn22 分钟前
matlab实现直流伺服电机 PID 控制系统仿真系统(含源码+资料报告+说明文档等)
开发语言·matlab
Hello--_--World25 分钟前
JS:this指向、bind、call、apply、知识点与相关面试题
开发语言·javascript·ecmascript
好家伙VCC34 分钟前
**基于RISC-V架构的嵌入式系统开发:从零开始构建高效低功耗应用**在当前物联网(IoT)和边缘计
java·python·物联网·架构·risc-v