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

示例:

给定一个链表: 1->2->3->4->5, 和 n = 2. 当删除了倒数第二个节点后,链表变为 1->2->3->5.

说明:

给定的 n 保证是有效的。

进阶:

你能尝试使用一趟扫描实现吗?

方法一:

两次遍历,第一次求长度。

方法二:

一次遍历,

first指针和second指针中间隔了n个节点,second ->next就是要删除的节点。当要删除的倒数长度和链表的长度相同时,会访问空指针,所以再设置一个头节点。

class Solution {
public:
ListNode* removeNthFromEnd(ListNode* head, int n) {
ListNode *h = new ListNode(0);
h ->next = head;
ListNode *first = h;
ListNode *second = h;
int temp = n + 1;
while(temp--)
{
first = first ->next;
}
while(first)
{
first = first ->next;
second = second ->next;
}
second ->next = second ->next ->next;
return h ->next;
}
};

最新文章

  1. HDU1671——前缀树的一点感触
  2. LeetCode 36 Valid Sudoku
  3. SQL SERVER 简介及应用 - 数据库系统原理
  4. .Net Core下如何管理配置文件
  5. [Android] WebView内的本地网页,使用XMLHttpRequest读取本地档案
  6. SQLAlchemy 中文文档翻译计划
  7. DJANGO中,用QJUERY的AJAX的json返回中文乱码的解决办法
  8. 20141016--for 兔子
  9. JQUERY的应用
  10. js中||和&&的用法
  11. 51单片机GPIO口模拟串口通信
  12. 6.使用桌面版AI伴侣或手机版AI伴侣实时预览编程效果
  13. JavaWeb基础-Jsp基础语法
  14. 七夕情人节表白-纯JS实现3D心形+图片旋转
  15. jQuery事件处理(六)
  16. python 之路06day
  17. 企业IM (或业务系统)web api的json格式设计思考(原创)
  18. SpringCloud教程 | 第四篇:断路器(Hystrix)(Finchley版本)
  19. 20154327 Exp1 PC平台逆向破解
  20. vs2008升级正式版

热门文章

  1. VMware的下载安装
  2. (转)剖析Linux文件编码的查看及修改
  3. Java-MyBatis-MyBatis3-XML映射文件:结果映射
  4. 更新CM版本
  5. Redis Set ZSet类型的学习
  6. Leetcode95. Unique Binary Search Trees II不同的二叉搜索树2
  7. 备份和恢复MySQL数据库
  8. object and namespace
  9. PHP--自动回调接口,分批修改数据
  10. 19-10-25-G-悲伤