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

文章目录

  • 题目描述
  • 思路 & 代码

题目描述

  • 重点在于一趟扫描实现
  • 简单的做法:一趟扫描长度,一趟根据长度找到结点删除
    在这里插入图片描述

思路 & 代码

  • 两种特例情况,见注释
  • 思路:根据N构造两个快慢指针,两指针直接差了N个结点。由此可以在扫描一趟结束的时候,让慢指针刚好在可以解决问题的结点位置。
/*** 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 removeNthFromEnd(ListNode head, int n) {// 特例1:单个的情况,直接返回null链表if(head.next == null){return null;}// 快慢指针做法ListNode fast = head, slow = head;// 快针先行while(n--!=0){fast = fast.next;}// 特例2:去掉头指针,此处fast=null说明要去掉的就是头指针if(fast == null){return head.next;}// 慢针开冲!while(fast.next!=null){fast = fast.next;slow = slow.next;}slow.next = slow.next.next;return head;}
}
  • 时间复杂度:O(n),一次遍历就完事
  • 空间复杂度O(1)

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

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

相关文章

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

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

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

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

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

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

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

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

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

删除第一张表的数据时,修改第二张表的相关字段的数值表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、动态规划)

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

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

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

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

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

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

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

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

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

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

文章目录题目描述代码 & 思路方法一:暴力法方法二:动态规划题目描述 当前列有水判断:左边最高列 & 右边最高列的短板不小于当前列 代码 & 思路 方法一:暴力法 对于每一列O(n),都找出左边最高列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;只需要循环一…

【LeetCode笔记】62. 不同路径(Java、动态规划)

文章目录题目描述代码 & 思路更新 2.0 版本题目描述 一眼bfs&#xff0c;不过超时了。。。好&#xff0c;那么我们就用动态规划来做&#xff01; 代码 & 思路 和走迷宫差不多&#xff0c;从终点往起点走。dp[i][j]代表(i&#xff0c;j&#xff09;到终点的可行路径…

【LeetCode笔记】64. 最小路径和(Java、动态规划)

文章目录题目描述代码 & 题目描述题目描述 动态规划&#xff0c;dp[][]都可以直接用grid[][]。空间复杂度O(1) 代码 & 题目描述 dp[i[j] grid[i][j] (grid[i-1][j] grid[i][j-1])&#xff0c;注意边界判断时间复杂度O(m*n) class Solution {public int minPath…

【LeetCode笔记】70. 爬楼梯(Java、动态规划)

文章目录题目描述代码 & 思路1. 动态规划 O(n)、O(n)2. 动态规划 O(n)、O(1)题目描述 DP 入门题了属于是 代码 & 思路 1. 动态规划 O(n)、O(n) dp[i]&#xff1a;可以到第 i 阶的方法有dp[i]种&#xff0c;所以dp[n]就是ans&#xff08;注意dp.length n1&#xf…

【LeetCode笔记】78. 子集(Java、dfs)

文章目录题目描述代码 & 思路更新2.0题目描述 不重复&#xff1a;用nowIndex即可&#xff0c;子集一定是下标有序的&#xff08;相对顺序和nums[]一样&#xff09; 代码 & 思路 轮流往下找即可注意&#xff1a;通过index来实现不重复&#xff0c;元素相对顺序一定要…