两数之和

简介: 给定整数数组 `nums` 和目标值 `target`,任务是在数组中找到和为 `target` 的两个整数并返回它们的下标。每个输入保证有唯一解,且不能重复使用同一元素。示例展示了不同情况下的输入与输出,暴力破解法通过两层循环遍历所有可能的组合来寻找解。

给定一个整数数组 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
只会存在一个有效答案

暴力破解法

class Solution {
    public int[] twoSum(int[] nums, int target) {
        int index1=0,index2=0;
        for(int i=0;i<nums.length-1;i++)
        {
            index1=i;
            for(int j=i+1;j<nums.length;j++)
            {
                if(nums[index1]+nums[j]==target)
                {
                    index2=j;
                    break;
                }
                else
                {
                    index2=0;
                }
            }
            if(index2>0)
            {
                break;
            }
        }
        int[]indexs=new int[]{index1,index2};
        return indexs;
    }
}

哈希方式

public int[] twoSum(int[] nums, int target) {
       Map<Integer, Integer> map = new HashMap<>();
        // 遍历数组
        for (int i = 0; i < nums.length; i++) {
            // 计算补数
            int complement = target - nums[i];
            // 检查补数是否在哈希表中
            if (map.containsKey(complement)) {
                // 如果在,返回两个数的索引
                return new int[] { map.get(complement), i };
            }
            // 将当前数和索引存入哈希表
            map.put(nums[i], i);
        }
        // 如果没有找到,抛出异常
        throw new IllegalArgumentException("No two sum solution");
    }
相关文章
|
Java Spring 容器
如何解决spring EL注解@Value获取值为null的问题
本文探讨了在使用Spring框架时,如何避免`@Value(&quot;${xxx.xxx}&quot;)`注解导致值为null的问题。通过具体示例分析了几种常见错误场景,包括类未交给Spring管理、字段被`static`或`final`修饰以及通过`new`而非依赖注入创建对象等,提出了相应的解决方案,并强调了理解框架原理的重要性。
759 5
|
存储 数据库 索引
客户端存储 —— IndexedDB 实现分页查询(下)
客户端存储 —— IndexedDB 实现分页查询
690 0
|
XML 存储 开发工具
|
3月前
|
Shell 网络安全 开发工具
项目快速导入git
本文介绍了如何在本地初始化 Git 仓库并将代码提交到远程仓库(如 GitHub 或 Gitee)的基本流程。内容包括安装 Git、创建仓库、添加文件、提交更改以及推送代码到远程仓库的详细步骤,适合初学者快速掌握 Git 的基本使用方法。
167 1
|
8月前
|
SQL 数据库 数据安全/隐私保护
Umbraco CMS 一键启动
**Umbraco 项目创建指南**您可以快速搭建并运行一个基于 Umbraco 的网站。
203 7
|
3月前
|
机器学习/深度学习 人工智能 PyTorch
三周内转型AI工程师学习计划
3周AI转型计划:掌握数学、机器学习与深度学习基础,熟练使用Python、PyTorch/TensorFlow。完成2-3个CV/NLP项目,构建GitHub博客,强化LeetCode刷题与模拟面试。每日高效学习9小时,聚焦实战与面试准备,助力快速入行AI。
246 0
|
11月前
|
人工智能 算法 搜索推荐
2024 “AI+硬件创新大赛”获奖名单出炉,浙大、上交与复旦联队等夺冠
2024年11月30日,由开放源子开源基金会主办,魔搭社区、英特尔与阿里云共同承办的“AI+硬件创新大赛”总决赛在杭州圆满落幕。
318 6
2024 “AI+硬件创新大赛”获奖名单出炉,浙大、上交与复旦联队等夺冠
|
11月前
|
人工智能 小程序 API
【一步步开发AI运动小程序】十三、自定义一个运动分析器,实现计时计数02
本文介绍如何利用“云智AI运动识别小程序插件”开发AI运动小程序,详细解析了俯卧撑动作的检测规则构建与执行流程,涵盖卧撑和撑卧两个姿态的识别规则,以及如何通过继承`sports.SportBase`类实现运动分析器,适用于小程序开发者。
|
11月前
|
敏捷开发 数据可视化 数据挖掘
进度追踪so easy!让你的团队分配任务像开挂一样
本文探讨了现代团队管理中任务分配与进度追踪的重要性,分析了跨部门协作、远程团队、任务优先级混乱及进度不可见等常见痛点,并推荐了几款高效管理工具,如板栗看板、Trello、Asana、Monday.com和Notion,分别适用于不同场景和需求,帮助团队提升协作效率。
273 12
|
11月前
|
运维 监控 负载均衡
slb后端服务器故障
slb后端服务器故障
217 13