【leetcode】1. 两数之和

博客围绕在整数数组中找出和为目标值的两个整数并返回其下标展开。给出两种解题思路,一是用双重循环,二是用map,以数组值为key、数组下标为value,通过循环判断找出符合条件的下标,最后输出结果为[0,1]。

第2周,做个简单的==

题目:

给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。

你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。

示例:

给定 nums = [2, 7, 11, 15], target = 9

因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]

 

解题思路:

我想到两种解题思路:

1.用双重循环,耗时长一些

2.用map,key为数组值,value为数组的第几个。循环数组,如果target-数组当前值=value,判断这value是否在map里,如果在,就根据"target-数组当前值"这个key取出,符合条件。如果没有,就把值放入map中。

 

代码:

package test.com;

import java.util.HashMap;


public class test2 {
    public int[] twoSum(int[] nums, int target) {
        int first;
        int second;
        int sum;
        for (int i=0;i<nums.length;i++){
            first=nums[i];
            for (int j = nums.length - 1; j > i; j--){
                second=nums[j];
                sum=first+second;
                if (sum==target){
                    int[]a=new int[]{i, j};
                    return a;
                }
            }
        }
        return null;
    }

    public static void main(String[] args) {
        test2 test2=new test2();
        int[] nums={2, 7, 11, 15};
        int target=9;
        int[]a = test2.twoSum2(nums,target);
    }

    public int[] twoSum2(int[] nums, int target) {
        HashMap<Integer, Integer> map = new HashMap<>();
        for (int i = 0; i < nums.length; i++){
            //判断如果map里面存在c=tar-当前循环i,证明 c+i=tar
            if (map.containsKey(target - nums[i])){
                return new int[]{map.get(target - nums[i]), i};
            }else{
                //没有 就把值放到map里面
                map.put(nums[i], i);
            }
        }
        return null;
    }
}

输出:

[0,1]

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值