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

文章目录

  • 20. 题目描述 & 解题
  • 21. 题目描述 & 解题
      • 1. 一开始的写法
      • 2. 参考大佬的写法

两道简单类型连着,就直接一起写了。

20. 题目描述 & 解题

  • 括号题是真挺烦人的。。。
  • 经典题目了,在学数据结构到栈的时候也会写到类似的题目
  • 其实主要就是:入的左括号,要遇到对应的右括号(就很符合栈)
    在这里插入图片描述
  • 左括号直接入栈
  • 右括号和pop的左括号匹配:不同则false
  • 结束后栈不是空的情况:说明括号数量不匹配,false
class Solution {public boolean isValid(String s) {Stack<Character> stack = new Stack<>();// 时间复杂度 O(n)for (char ch : s.toCharArray()) {// 左括号直接入if (ch == '(' || ch == '[' || ch == '{') {// 空间复杂度O(n)stack.push(ch);}else {// 先出现右括号的情况if(stack.empty())return false;char left = stack.pop();switch (left){// 三种右括号未能正确对应左括号的情况case '(':{if(ch!=')'){return false;}break;}case '[':{if(ch!=']'){return false;}break;}case '{':{if(ch!='}'){return false;}break;}default:break;}}}if(stack.empty()){return true; }// 括号数量对不齐的情况return false;}
}
  • 时间复杂度 O(n):就是遍历一遍括号集合
  • 空间复杂度 O(n):括号集合纳入栈中

21. 题目描述 & 解题

  • 记得考虑链表空的情况
    在这里插入图片描述

1. 一开始的写法

/*** Definition for singly-linked list.* public class ListNode {*     int val;*     ListNode next;*     ListNode() {}*     ListNode(int val) { this.val = val; }*     ListNode(int val, ListNode next) { this.val = val; this.next = next; }* }*/
class Solution {public ListNode mergeTwoLists(ListNode l1, ListNode l2) {// 有链表为空的情况if(l1==null)return l2;if(l2==null)return l1;ListNode l3 = new ListNode();ListNode l1n = l1, l2n = l2, l3n = l3;// 遍历两条链表,时间复杂度O(m+n)// 空间复杂度O(m+n);while(l1n!=null || l2n!=null){if(l2n.val > l1n.val){l3n.val = l1n.val;l1n = l1n.next;}else{l3n.val = l2n.val;l2n = l2n.next;}// 跑完某个链表的情况,直接连上另外一条。if(l2n==null){l3n.next = l1n;break;}if(l1n==null){l3n.next = l2n;break;}ListNode newNode = new ListNode();l3n.next = newNode;l3n = l3n.next;}return l3;}
}
  • 遍历两条链表,时间复杂度O(m+n)
  • 空间复杂度O(m+n)

2. 参考大佬的写法

就很巧妙,又快又好

  • 应该是分治?递归得很巧妙。
/*** Definition for singly-linked list.* public class ListNode {*     int val;*     ListNode next;*     ListNode() {}*     ListNode(int val) { this.val = val; }*     ListNode(int val, ListNode next) { this.val = val; this.next = next; }* }*/
class Solution {public ListNode mergeTwoLists(ListNode l1, ListNode l2) {// 有链表为空的情况if(l1==null)return l2;if(l2==null)return l1;// 一层递归加一个结点// 复杂度为O(m+n),归根结底还是要遍历每个结点// 空间复杂度O(1),根本不用额外空间= =else if(l1.val < l2.val){l1.next = mergeTwoLists(l1.next,l2);return l1;}else{l2.next = mergeTwoLists(l2.next,l1);return l2;}}
}

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

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

相关文章

matlab将数扩大为整数,MATLAB如何完成大整数运算问题?

Forcal&#xff0b;HugeCalc可以计算下面的数(只有指数部分不能是大整数)&#xff1a;(1000!)^1000%(2000!)代码&#xff1a;!using["HugeCalc"];mvar:i: oo{aHI[0].Fac[1000], //1000!bHI[0].Fac[2000], //2000!printff["\r\n"],[Pow(a,1000)%b].Show[]…

【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&…

matlab画三维实心圆柱体,怎样用matlab画水平实心圆柱体,已知圆柱体的半径和高度(悬? 爱问知识人...

clear allr1;%圆柱半径n100;%设置多少个边逼近圆h5;%圆柱高[x,y,z]cylinder(r,n);%生成标准的100个面的圆柱数据&#xff0c;半径为r&#xff0c;高为1&#xff0c;底面圆心0&#xff0c;0&#xff1b;z1[z(1,:);z(2,:) h-1];%圆柱高增高&#xff0c;变为高h%为变成实心封顶添加…

【LeetCode笔记(水)】s = null 与 s.length() == 0

来水一篇博客&#xff0c;加固一下印象 在刷题过程&#xff0c;经常要考虑输入值为空的情况。其中&#xff0c;输入值为字符串、数组或者链表时&#xff0c;有两种需要判断的情况&#xff0c;此处以String s 为例 s null; 也就是s还没有占用存储空间。s.length 0; s占用存储…

php umount强制,linux中mount/umount命令的基本用法及开机自动挂载方法

本文介绍了linux中mount/umount命令的基本用法及开机自动挂载&#xff0c;具体方法如下&#xff1a;mount命令格式如下&#xff1a;格式&#xff1a;mount [-参数] [设备名称] [挂载点]其中常用的参数有&#xff1a;-a 安装在/etc/fstab文件中类出的所有文件系统。-f 伪装mount…

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

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

php分页类smary,Smarty分页实现方法完整实例

这篇文章主要介绍了Smarty分页实现方法,涉及基于Smarty的数据库查询、分页相关计算与模板操作技巧,需要的朋友可以参考下本文实例讲述了Smarty分页实现方法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;首先是PHP文件部分&#xff1a;require("include.php&quo…

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

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

301.inc.php,DeDeCMS默认首页及WWW域的301跳转

你是否留心过&#xff1a;通过域名访问网站首页时&#xff0c;网页返回Http状态码是什么&#xff1f;甚至访问内页时&#xff0c;Http状态码又是什么吗&#xff1f;大多数人可能会想当然的认为首页返回的肯定是200&#xff0c;因为我们很容易观察到首页能否可以正常打开以及URL…

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

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

【LeetCode笔记】34. 在排序数组中查找元素的第一个和最后一个位置(Java、二分)

文章目录题目描述思路 & 代码1. 暴力法2. 二分法3. 二分法——简略版题目描述 老套路了&#xff0c;有序找元素&#xff0c;直接冲二分思路是不难想&#xff0c;就是边界条件限制条件有点恶心&#xff0c;时不时爆个栈 思路 & 代码 1. 暴力法 一次遍历找到left&am…

【LeetCode笔记】42. 接雨水(Java、动态规划)

文章目录题目描述代码 & 思路方法一&#xff1a;暴力法方法二&#xff1a;动态规划题目描述 当前列有水判断&#xff1a;左边最高列 & 右边最高列的短板不小于当前列 代码 & 思路 方法一&#xff1a;暴力法 对于每一列O(n)&#xff0c;都找出左边最高列O(n)&a…

【LeetCode笔记】46. 全排列(Java、DFS回溯、队列)

文章目录题目描述代码 & 思路题目描述 老简单了&#xff0c;一眼就是用visited数组记录出现过的数字&#xff0c;依次基础上进行回溯即可和前面的题目很像&#xff0c;用队列结合回溯使用 代码 & 思路 class Solution {public List<List<Integer>> per…

【LeetCode笔记】48. 旋转图像(Java、矩阵、偏数学、原地算法)

文章目录题目描述代码 & 思路题目描述 矩阵题&#xff0c;一眼就感觉很烦&#xff0c;直接看了题解 因为要求原地旋转&#xff0c;所以只能用temp来做当然&#xff0c;我们还是要回顾一下矩阵转置的&#xff0c;看看和这道题有啥不同&#xff0c;说不定就能用上呢。好的&a…

【LeetCode笔记】49. 字母异位词分组(Java、字符串、哈希表)

文章目录题目描述代码 & 思路题目描述 考虑&#xff1a;如何把字母相同、排列不同的字符串组合成一个相同的、独一无二的东西&#xff1f;尝试1&#xff1a;使用ascii的和&#xff08;不行&#xff0c;虽然说确实相同&#xff0c;但是独一无二不满足&#xff09;尝试2&…

【LeetCode笔记】55. 跳跃游戏(Java、贪心法)

文章目录题目描述解法 & 思路题目描述 可以用动态规划来做&#xff0c;dp[i]代表以第i个下标做起点&#xff0c;可以到达的最远的地方&#xff0c;从后往前走&#xff0c;最后dp[0] > len-1说明可达。不过我的dp相对于贪心法慢了不少(400ms&#xff09; 解法 & 思…

【LeetCode笔记】56. 合并区间(Java、排序)

文章目录题目描述代码 & 思路更新版 2.0题目描述 重叠区间&#xff1a;需要有重叠判断注意&#xff1a;题目并没有说集合间有序&#xff0c;因此要先做一个排序&#xff0c;以左下标为排序值&#xff08;否则会出错 代码 & 思路 经过排序后&#xff0c;只需要循环一…