【LeetCode笔记】1. 两数之和(JAVA、哈希表)

文章目录

  • 一. 题目描述
  • 二. 解法
      • ① 暴力破解
      • ② 静态哈希表
          • 1. 为什么用哈希表来做
          • 2. 特殊情况:两数相同,map映射覆盖
      • ③ 动态哈希表
      • ④ 未解之谜

诶嘿,经典开头题目

一. 题目描述

数组中同一个元素不能使用两遍:

  • 见实例2,实际过程可能出现输出为[0,0]的情况,就是同一元素使用了两遍,要注意判断

在这里插入图片描述

二. 解法

① 暴力破解

看到题干,首选暴力。
只需要遍历数组:对于数组中的每一个元素,都和后面的所有元素进行一次匹配即可。

class Solution {public int[] twoSum(int[] nums, int target) {for(int i=0;;i++){for(int j=i+1;j<nums.length;j++){if(nums[i]+nums[j]==target)return new int[]{i,j};}}}
}
  • 时间复杂度为O(n2n^2n2),空间复杂度为O(1)

现在题目解出来了,但是要怎么优化呢?
看到上述的时空复杂度,可以这么想:时间复杂度和空间复杂度不太均衡,可不可以试一下把时间上的负担分一点到空间上呢?

② 静态哈希表

class Solution {public int[] twoSum(int[] nums, int target) {Map<Integer, Integer> hashtable = new HashMap<Integer, Integer>();// 先构建哈希表for(int i=0;i<nums.length; ++i)hashtable.put(nums[i],i);// 再遍历数组,结合哈希表进行查找for(int i=0;i<nums.length; ++i){if(hashtable.containsKey(target - nums[i])){// 这边这个判断不能少,否则出现同一元素使用两次的情况if(hashtable.get(target - nums[i])!=i)return new int[]{hashtable.get(target - nums[i]),i};}}return new int[0];}
}
  • 时间复杂度O(n),空间复杂度O(n)
1. 为什么用哈希表来做

暴力法的时间复杂度由来:n(遍历数组元素)* n(查找能和当前数组组合成target的元素)。
而这个查找的O(n),如果是用哈希表来实现则是O(1)
而由于需要构建出哈希表,我们需要付出O(n)的空间复杂度代价。

2. 特殊情况:两数相同,map映射覆盖

描述:使用两个数据值相同,下标不同的元素。而我们在建立映射表时使用的键值是数据值,因此下标大的元素会覆盖之前的元素,变成新的映射,导致有些映射会丢失。

理解:考虑了好久。。。其实这样子不会出问题

  • 首先保留的是下标大的元素的映射
  • 然后,我们在遍历时使用的是数组,而且是先遇到下标小的元素。
    对这个小的元素进行哈希表查找,刚好可以找到下标大的元素。就可以得到正确的结果

③ 动态哈希表

class Solution {public int[] twoSum(int[] nums, int target) {Map<Integer, Integer> hashtable = new HashMap<Integer, Integer>();for (int i = 0; i < nums.length; ++i) {if (hashtable.containsKey(target - nums[i])) {return new int[]{hashtable.get(target - nums[i]), i};}hashtable.put(nums[i], i);}return new int[0];}
}
  • 时间复杂度O(n),空间复杂度O(n)
  • 目前了解的最好的方法
  • 在②的基础上,会比较好理解
  • 在②之上的优化
  1. 不需要进行相同元素的判断:当出现与之前值相同,并且可以组成target的值时,就直接满足return条件了。
    比如实例3,先存储<3,0>映射;到nums[1]的时候,不需要覆盖<3,1>映射,而是满足if判断,直接返回[0,1]。
  2. 占用的时间空间会更小:因为是一边建哈希表一边找answer的,所以很大概率在完全建表之前就找到answer。

④ 未解之谜

这一块是无伤大雅,但是想弄明白的地方

  1. 增强型for循环溢出
    = =这个解决了,应该把nums改成nums.length,还是用得不够熟悉。
// 正常for循环,不会出错
for(int i=0;i<nums.length; ++i)hashtable.put(nums[i],i);
// 增强型for循环,会出现越界错误
for(int i : nums)hashtable.put(nums[i],i);
  1. 需要额外写return
// ②③如果只有if的return,编译器会报错:“missing return statement”,但是①却不需要
return new int[0];

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/504623.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java spring入门小程序_springMVC学习笔记(二)-----注解和非注解入门小程序

最近一直在做一个电商的项目&#xff0c;周末加班&#xff0c;忙的都没有时间更新博客了。终于在上周五上线了&#xff0c;可以轻松几天了。闲话不扯淡了&#xff0c;继续谈谈springMvc的学习。现在&#xff0c;用到SpringMvc的大部分使用全注解配置&#xff0c;但全注解配置也…

【LeetCode笔记】2. 两数相加(JAVA、链表)

文章目录题目描述代码题目描述 解法&#xff1a;直接用两个链表构造出第三个链表即可注意点&#xff1a;进位carry。进位的情况有几种&#xff0c;都要考虑上。&#xff08;其实感觉这道题不是很难&#xff0c;挺直观的&#xff09; 代码 时间复杂度&#xff1a;O(max(m,n)…

【LeetCode笔记】3. 无重复字符的最长子串(JAVA、滑动窗口、字符串)

文章目录题目描述思路 && 代码1. 之前的版本更新 2.0题目描述 子串&#xff1a;各字符间必须要相邻&#xff0c;而非子序列使用滑动窗口来做就行 思路 && 代码 1. 之前的版本 思路&#xff1a;维护一个滑动窗口&#xff0c;滑动窗口中容纳一个无重复字符的…

【LeetCode笔记】5.最长回文子串(Java、动态规划、字符串)

文章目录题目描述解法 & 代码&#xff1a;思路题目描述 回文&#xff1a;正着念和倒着念一样。 解法 & 代码&#xff1a; 一开始看到子串&#xff0c;想着可能no.3最长重复子串一样用滑动窗口。不过回文串的判断会很麻烦&#xff0c;于是舍弃。之后看题解&#xff…

【LeetCode笔记】6. Z字形变化(JAVA、思路)

文章目录题目描述解题 & 代码二维数组ArrayList && StringBuilder题目描述 这题目有点搞&#xff0c;理解题意得时候直接结合给的例子比较好。本质就是&#xff1a;从顶部开始&#xff0c;往下逐个走&#xff1b;到底了就反向&#xff0c;往上逐个走&#xff1b;以…

【LeetCode笔记】7.整数反转(Java、溢出判断、栈)

文章目录题目描述解法 & 代码① 字符串解法② 类栈做法题目描述 边界比较需要考虑&#xff0c;而且还有不允许64位整数的要求。 解法 & 代码 ① 字符串解法 起初想到的做法&#xff0c;不过缺点比较多首先用到了long&#xff0c;实际上不允许使用&#xff0c;修改…

java 接口中变量修饰符,Java的访问修饰符与变量的作用域讲解

Java访问修饰符(访问控制符)Java 通过修饰符来控制类、属性和方法的访问权限和其他功能&#xff0c;通常放在语句的最前端。例如&#xff1a;?Java 的修饰符很多&#xff0c;分为访问修饰符和非访问修饰符。本节仅介绍访问修饰符&#xff0c;非访问修饰符会在后续介绍。访问修…

【LeetCode笔记】11.盛最多水的容器(Java、双指针法)

文章目录题目描述代码 & 解题思路题目描述 无 代码 & 解题思路 思路&#xff1a;使用左右两个指针&#xff0c;不断缩小范围&#xff0c;并在每次缩小的过程对最大值进行更新。代码实现不难&#xff0c;主要是弄明白为啥这样做就能得到正确的值简单描述就是&#x…

【LeetCode笔记】15.三数之和(JAVA、双指针)

文章目录题目描述代码 & 解题思路二刷更新题目描述 主要是解决重复的问题&#xff1a;如何去除重复解、在有大量重复解的情况下如何让算法跑得更快 代码 & 解题思路 先排序&#xff0c;按照大小顺序来做。思路&#xff1a;固定第一个数&#xff0c;用双指针分别代表…

【LeetCode笔记】17.电话号码的字母组合(Java、DFS)

文章目录题目描述代码 & 思路题目描述 得建立映射&#xff0c;其实用数组来建立也行&#xff0c;看起来还比较直观。 代码 & 思路 理好DFS的过程就行&#xff0c;整体思路不难当递归字符length 1时&#xff0c;递归结束 class Solution {public List<String&g…

【LeetCode笔记】19.删除链表的倒数第N个结点(Java、快慢指针)

文章目录题目描述思路 & 代码题目描述 重点在于一趟扫描实现简单的做法&#xff1a;一趟扫描长度&#xff0c;一趟根据长度找到结点删除 思路 & 代码 两种特例情况&#xff0c;见注释思路&#xff1a;根据N构造两个快慢指针&#xff0c;两指针直接差了N个结点。由此…

java xca碗组口径,公路车常见杂音检查清单和解决方法(图文)

爱车上出现杂音是件很不爽的事&#xff0c;我本人就很不能容忍任何异响。相信这也是困扰广大车友的问题之一&#xff0c;于是我根据自己和周围车友的经验以及网上的资源&#xff0c;整理出这份清单&#xff0c;希望能给遇到此类问题的车友们一些帮助。写在前面&#xff1a;当异…

【LeetCode笔记】20.有效的括号(Java、栈) 21. 合并两个有序链表(Java)

文章目录20. 题目描述 & 解题21. 题目描述 & 解题1. 一开始的写法2. 参考大佬的写法两道简单类型连着&#xff0c;就直接一起写了。 20. 题目描述 & 解题 括号题是真挺烦人的。。。经典题目了&#xff0c;在学数据结构到栈的时候也会写到类似的题目其实主要就是&a…

【LeetCode笔记】22.括号生成(Java、DFS回溯、剪枝、括号)

文章目录题目描述代码 & 解法题目描述 先吐槽&#xff1a;括号题好恶心。。括号有效判断需要考虑考虑 代码 & 解法 思路&#xff1a;把括号分开看&#xff0c;这道题和20.有效的括号其实是有差别的&#xff1a;这道题的括号是成对的&#xff0c;而20题的括号则没有…

【LeetCode笔记】23.合并K个升序列表(Java、分治、链表)

文章目录题目描述解法 & 代码二刷冲的第一道hard&#xff0c;好耶&#xff01; 题目描述 这道题和前面的合并两个有序链表很有联系。直接调用了整个合并函数。可以看成我们已经有了足够优秀的“两条链表合并“的函数&#xff0c;然后考虑对K条链表如何进行合并分配。结构类…

php删除一张表数据的时候 把另一张表的数据也删除,剔除第一张表的数据时,修改第二张表的相关字段的数值...

删除第一张表的数据时&#xff0c;修改第二张表的相关字段的数值表xfxf_id vip total1 1 102 1 1003 2 804 3 50表vipvip jifen1 10002 5003 800$sql "delete from " . $fdyu->table(xf) ." WHERE xf_id " . db_create_in(join(,, $_POST[checkboxes])…

【LeetCode笔记】53. 最大子序和(Java、动态规划)

文章目录题目描述代码 & 思路题目描述 经典题目了&#xff0c;多种解法&#xff08;不过目前只学了一种&#xff0c;暴力不算&#xff09; 代码 & 思路 这块基本上算是写给自己看的了。。写得不好&#xff0c;如果想学这种方法最好还是去leetcode题解看。 sum num&…

【LeetCode笔记】32. 最长有效括号(Java、动态规划、栈、字符串)

文章目录题目描述代码 & 解析1. 栈做法2. 动态规划题目描述 &#xff08;括号题真的好烦人&#xff09;讲道理&#xff0c;题目一看&#xff0c;大概率就是用dp做 代码 & 解析 1. 栈做法 这个做法我没实际写&#xff0c;但是感觉很厉害&#xff0c;就记录一下。我…

【LeetCode笔记】33. 搜索螺旋排序数组(Java、二分)

文章目录题目描述思路 & 代码题目描述 有序数组中搜索值&#xff0c;显然用二分旋转带来的影响并不大&#xff0c;只要多加几个判断&#xff0c;改改范围就行。 思路 & 代码 首先找出两部分升序子数组的分割点k然后再判断需要在哪个子数组进行二分&#xff0c;并进…

【LeetCode笔记】39. 组合总和(Java、DFS回溯、队列)

文章目录题目描述思路 & 代码题目描述 讲道理&#xff0c;像这种找可行集合解的问题&#xff0c;基本上都可以通过回溯 剪枝来做 思路 & 代码 sort()用于优化&#xff0c;多一个剪枝判断&#xff0c;其实也可以不写双向队列deque&#xff1a;第一次用&#xff0c;…