【做题笔记一】两个数求和

【做题笔记一】两个数求和

题目链接:https://leetcode.com/problems/two-sum/
题目描述:
给定一个整数数组,返回这两个数字的索引,使它们加到一个特定的目标上。
您可以假设每个输入都恰好有一个解决方案,并且可能不会两次使用相同的元素。
例子:
给定 nums=[2,7,11,15],target=9,
因为 nums[0]+nums[1]=2+7=9,
所以 return[0, 1 ]。

解题思路:

  1. 蛮力法

由于题目比较简单,测试用例也不多,所以只需要在数组之间中两两匹配就能解决问题。由于题目没说是有序数组,所以要匹配完所有数字。蛮力解题的时间复杂度就是O(n^2),空间复杂度为O(1)。
代码如下:

    class Solution {
        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){
                        int[] temp = {i,j};
                        return temp;
                     }``
                }
            }
            return new int[2];
        }
    }

耗时:25ms

  1. 双通哈希表

这个map函数不是很懂所以直接贴代码

class Solution {
    public int[] twoSum(int[] nums, int target) {
    Map<Integer, Integer> map = new HashMap<>();
    for (int i = 0; i < nums.length; i++) {
        map.put(nums[i], i);
    }
    for (int i = 0; i < nums.length; i++) {
        int complement = target - nums[i];
        if (map.containsKey(complement) && map.get(complement) != i) {
            return new int[] { i, map.get(complement) };
        }
    }
    throw new IllegalArgumentException("No two sum solution");
}
}

耗时:9ms
通过耗时可以明显看出方法二比方法一效率高得多。

感悟:自己只想到蛮力法,哈希表是官方给的一个解决方法推荐,个人基础能力不足,java基础的4种类型基本都没有深入了解,所以这个也算一个提高自己的过程。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值