LeetCode19----删除链表的指定元素
2024-10-07 01:57:45
给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。
示例:
给定一个链表: 1->2->3->4->5, 和 n = 2. 当删除了倒数第二个节点后,链表变为 1->2->3->5.
说明:
给定的 n 保证是有效的。
进阶:
你能尝试使用一趟扫描实现吗?
该题目的要求是只需要扫描一次就可以实现,那么我们就不可能去创建一个数组来解决该问题,因为把链表元素全部放进数组就要扫描一次,而把删除后的数组放入链表又要扫描一次,所以我们这里采用创建额外的指针来解决该问题!!
代码如下:
public class LeetCode19 {
public static class ListNode {
int val;
ListNode next; ListNode(int x) {
val = x;
}
} public ListNode removeNthFromEnd(ListNode head, int n) {
if (head == null) {
return null;
}
int k = 0;
ListNode low = head;
ListNode fast = head;
while (k < n - 1) {
fast = fast.next;
k++;
}
ListNode lastLow = null;
while (true) {
if (fast.next != null) {
fast = fast.next;
lastLow = low;
low = low.next;
} else {
if (lastLow == null) {
return low.next;
} else {
lastLow.next = low.next;
low.next = null;
return head;
}
}
}
}
}
最新文章
- 解决Jquery Kendo.xxx is not a function 的方法
- DBCC CHECKDB 遭遇Operating system error 112(failed to retrieve text for this error. Reason: 15105) encountered
- socket.io 入门教程
- MaraDNS与DeadWood一起配置为本地机器提供小型化DNS服务
- Java下载Servlet Demo
- SpringBoot Quickstart
- .NET的微型Web框架 Nancy
- ubuntu输入某个目录测试该目录里.C文件里代码行数shell脚本
- SOFA 源码分析 — 链路数据透传
- Nctf_web_wp
- 字符串的顺序倒置。(Reverse)
- python_str 字符串的所有方法
- 移动端FastClick和editor冲突问题。
- (广度搜索)A - Prime Path(11.1.1)
- this高级应用 - 域隔离
- Jquery 保留N位小数,且千位以上用";,";号隔开
- 使用spring整合Quartz实现—定时器
- 关于Python的面试题
- 【max_result_window大小】 Result window is too large的问题
- spark 例子groupByKey分组计算