两数之和

简介: 给定整数数组 `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");
    }
相关文章
|
7月前
|
存储 C++
两数相加(C++)
两数相加(C++)
48 0
|
2月前
|
Python
01、两数之和——2021-04-12
01、两数之和——2021-04-12
10 0
|
2月前
|
存储
Leetcode第29题(两数相除)
LeetCode第29题要求使用不包含乘法、除法和mod运算符的方法计算两个整数的商,通过记录结果的正负,将问题转化为负数处理,并利用二进制幂次方的累加来逼近除数,最后根据结果的正负返回相应的商。
18 0
|
2月前
|
Go Python
01.两数之和
01.两数之和
15 0
|
4月前
|
算法
LeetCode第29题两数相除
这篇文章介绍了LeetCode第29题"两数相除"的解题方法,通过使用加法、减法和二进制位移法代替常规的乘除操作,并考虑了整数溢出问题,提供了一种高效的算法解决方案。
LeetCode第29题两数相除
|
6月前
1.两数之和
1.两数之和
|
7月前
leetcode-29:两数相除
leetcode-29:两数相除
46 0

热门文章

最新文章