【做题笔记一】两个数求和
题目链接:https://leetcode.com/problems/two-sum/
题目描述:
给定一个整数数组,返回这两个数字的索引,使它们加到一个特定的目标上。
您可以假设每个输入都恰好有一个解决方案,并且可能不会两次使用相同的元素。
例子:
给定 nums=[2,7,11,15],target=9,
因为 nums[0]+nums[1]=2+7=9,
所以 return[0, 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
- 双通哈希表
这个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种类型基本都没有深入了解,所以这个也算一个提高自己的过程。