给定一个链表,删除链表的倒数第 个节点,并且返回链表的头结点。

示例:

给定一个链表: 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;
}
}
}
}
}

  

最新文章

  1. 解决Jquery Kendo.xxx is not a function 的方法
  2. DBCC CHECKDB 遭遇Operating system error 112(failed to retrieve text for this error. Reason: 15105) encountered
  3. socket.io 入门教程
  4. MaraDNS与DeadWood一起配置为本地机器提供小型化DNS服务
  5. Java下载Servlet Demo
  6. SpringBoot Quickstart
  7. .NET的微型Web框架 Nancy
  8. ubuntu输入某个目录测试该目录里.C文件里代码行数shell脚本
  9. SOFA 源码分析 — 链路数据透传
  10. Nctf_web_wp
  11. 字符串的顺序倒置。(Reverse)
  12. python_str 字符串的所有方法
  13. 移动端FastClick和editor冲突问题。
  14. (广度搜索)A - Prime Path(11.1.1)
  15. this高级应用 - 域隔离
  16. Jquery 保留N位小数,且千位以上用&quot;,&quot;号隔开
  17. 使用spring整合Quartz实现—定时器
  18. 关于Python的面试题
  19. 【max_result_window大小】 Result window is too large的问题
  20. spark 例子groupByKey分组计算

热门文章

  1. java代码--Date类获取当前时间-格式化输出
  2. 关于Android studio调用高德地图的简单流程和要点
  3. 安装kubuctl
  4. 线程的函数中调用MFC对话框类的变量
  5. 改变font-weight的数值,样式并不会改变的原因
  6. 记一次nodemanager无法启动的情况
  7. dedecms 调用内容页分页
  8. Delphi SpeedButton组件
  9. 一般情况下的NB-IoT网络架构
  10. 1.shell编程-变量的高级用法