给定一个链表,删除链表的倒数第 n 个节点,并且返回链表的头结点。
示例:
给定一个链表: 1->2->3->4->5, 和 n = 2.
当删除了倒数第二个节点后,链表变为 1->2->3->5.
 说明:
给定的 n 保证是有效的。
进阶:
你能尝试使用一趟扫描实现吗?
快慢指针法
一次遍历就可以完成,我运用了三个指针来完成
刚开始,第一个p,第二个r指针指向第一个节点,第三个指针q指向第n-1个节点
之后第一个指针,第三个指针向后移动,第二个指针指向第一个指针的前一个节点(一会方便删除)
当第三个指针q的下一个指向为空时,说明第一个指针p所指向的节点就是需要删除的节点
那么r.next = r.next.next就可以直接删除
可以直接提交的代码:
class Solution {
     public ListNode removeNthFromEnd(ListNode head, int n) {
        ListNode p,q,r;
         p = head;
         q = head;
         r = p;
         int i;
         if(head.next==null) 
         {
             head = null;
             return head;
         }
         for(i=1;i<n;i++)
         {
             q = q.next;
         }
         if(q.next==null)
         {
             head = head.next;
         }
         while(q.next!=null)
         {
             r = p;
             p = p.next;
             q = q.next;
         }
         r.next = r.next.next;
         return head;
     }
 }
完整代码:
package Solution19;
public class Solution19 {
     public static ListNode removeNthFromEnd(ListNode head, int n) {
         ListNode p,q,r;
         p = head;
         q = head;
         r = p;
         int i;
         if(head.next==null) 
         {
             head = null;
             return head;
         }
         for(i=1;i<n;i++)
         {
             q = q.next;
         }
         if(q.next==null)
         {
             head = head.next;
         }
         while(q.next!=null)
         {
             r = p;
             p = p.next;
             q = q.next;
         }
         r.next = r.next.next;
         return head;
     }
     public static void main(String[] args)
     {
         ListNode head = new ListNode(1);
         ListNode p = head;
         ListNode q = new ListNode(2);
         p.next = q;
         p = q;
         q = new ListNode(3);
         p.next = q;
         p = q; 
         q = new ListNode(4);
         p.next = q;
         p = q; 
         q = new ListNode(5);
         p.next = q;
         p = q; 
         p.next = null;
         head = removeNthFromEnd(head,2);
         while(head!=null)
         {
             System.out.println(head.val);
             head = head.next;
         }
     }
 }