[LeetCode][Java] Remove Nth Node From End of List

原创 2015年07月09日 20:52:08

题目:

Given a linked list, remove the nth node from the end of list and return its head.

For example,

   Given linked list: 1->2->3->4->5, and n = 2.

   After removing the second node from the end, the linked list becomes 1->2->3->5.

Note:
Given n will always be valid.
Try to do this in one pass.


题意:

给定一个链表,去除距离尾节点第n个的节点,返回去除节点后的头结点。

例如:

   Given linked list: 1->2->3->4->5, and n = 2.

   After removing the second node from the end, the linked list becomes 1->2->3->5.
注意:

给定的n都是有效的。

试着一次遍历就得出结果。


算法分析:

Use fast and slow pointers. The fast pointer is n steps ahead of the slow pointer. When the fast reaches the end, the slow pointer points at the previous element of the target element.

利用快慢双指针。快指针在慢指针之前n步。当快指针到达链表的结尾时,慢指针正好指向了目标元素的头一个元素。

AC代码:

public class Solution 
{
    public ListNode removeNthFromEnd(ListNode head, int n) 
    {
        if(head == null)
            return null;
     
        ListNode fast = head;
        ListNode slow = head;
     
        for(int i=0; i<n; i++)
        {
            fast = fast.next;
        }
     
        //if remove the first node
        if(fast == null)
        {
            head = head.next;
            return head;
        }
     
        while(fast.next != null)
        {
            fast = fast.next;
            slow = slow.next;
        }
     
        slow.next = slow.next.next;
     
        return head;
    }
}


版权声明:本文为博主原创文章,转载注明出处

【LeetCode-面试算法经典-Java实现】【019-Remove Nth Node From End of List(移除单链表的倒数第N个节点)】

【019-Remove Nth Node From End of List(移除单链表的倒数第N个节点)】【LeetCode-面试算法经典-Java实现】【所有题目目录索引】原题  Given a l...
  • DERRANTCM
  • DERRANTCM
  • 2015年07月22日 07:24
  • 2061

Java list.remove( )方法需要注意的两个地方

list.remove最近做项目的过程中,需要用到list.remove()方法,结果发现两个有趣的坑,经过分析后找到原因,记录一下跟大家分享一下。代码直接上一段代码,进行分析。public clas...
  • DeMonliuhui
  • DeMonliuhui
  • 2017年07月13日 14:41
  • 2214

Java list.remove( )方法需要注意的两个地方

public class Main { public static void main(String[] args) { List stringList = new Arra...
  • anmoyyh
  • anmoyyh
  • 2017年07月24日 14:03
  • 661

ArrayList删除元素(remove())报错的原理与解决办法

作为Java大家庭中的集合类框架,List应该是平时开发中最常用的,可能有这种需求,当集合中的某些元素符合一定条件时,想要删除这个元素。如: [java] view plaincop...
  • mingliangniwo
  • mingliangniwo
  • 2015年10月21日 11:25
  • 6284

for循环删除(ArrayList.remove)报错及解决办法

[java]   List list = new ArrayList();   list.add(1);   list.add(2);   list.add(3);   ...
  • u010523770
  • u010523770
  • 2016年07月18日 17:26
  • 6427

java中的ArrayList类中的remove方法

在java中如果调用了ArrayList中的remove方法,其本质上是将要remove的对象与list中的每一个对象进行比较,比较的方法是调用Object中的equals方法,本质上是比较2个对象的...
  • liqing08229
  • liqing08229
  • 2013年05月22日 15:12
  • 18719

Java编程:List.remove()、equals() 方法解惑

下午写了一段代码,大致的处理的业务是这样的: 有一个 TreeNode 类型的 List,TreeNode 有一个 nodeId 属性, 如果 nodeId 字符串的第 index 索引位置的字符不...
  • claram
  • claram
  • 2016年11月28日 19:25
  • 802

集合类的remove(obj)和iterator的remove方法差别

java.util.ConcurrentModificationException 工作中碰到个ConcurrentModificationException。代码如下: List list = .....
  • xad707348125
  • xad707348125
  • 2015年04月16日 15:31
  • 1822

遍历List 同时 remove 元素

List list = new ArrayList(); list.add(1); list.add(2); list.add(3); list.add(4); list.add(...
  • Vestigge
  • Vestigge
  • 2013年01月21日 14:22
  • 3737

在for循环中remove list报错越界的问题

最近在搞一个购物车的功能,里面有一个批量删除的操作,采用的是ExpandableListView以及BaseExpandableListAdapter。视乎跟本篇无关紧要,主要是为了记录一个java基...
  • z_zT_T
  • z_zT_T
  • 2017年04月18日 15:22
  • 759
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[LeetCode][Java] Remove Nth Node From End of List
举报原因:
原因补充:

(最多只允许输入30个字)