`
vvaaiinn
  • 浏览: 22010 次
  • 性别: Icon_minigender_1
  • 来自: 大连
文章分类
社区版块
存档分类
最新评论

LeetCode 19 Remove Nth Node From End of List 移除倒数第N个节点

 
阅读更多

题目:

Given a linked list, remove thenthnode 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:
Givennwill always be valid.
Try to do this in one pass.

翻译:

给你一个链表,移除倒数第N个节点。

思路:

这道题难度还行,就是一些细节的方面,首先可能链表就一个节点。其次有可能被删除的是第一个节点。最后就是删除该节点后节点的连接。

代码:

	 public ListNode removeNthFromEnd(ListNode head, int n) {
	         if(head==null||(head.next == null && n ==1))
	        	return null;
	        
	        ListNode p = head;
	        ListNode q = head;
	        ListNode pre = head;
	        while(n!=1)
	        {
	        	q = q.next;
	        	n--;
	        }
	        while(q.next!=null)
	        {
	            pre = p;
	        	q = q.next;
	        	p = p.next;
	        }
	        if(pre.next == p.next)
	            head = head.next;
	        else 
	            pre.next = p.next;

	        return head;
	        
	    }
我采用的办法是两个指针p,q,q先遍历到n-1的位置,然后两个指针同时向后遍历,直到q到结尾,此时p为应该删去的。同时来个指针指向p的前一个。

如果p 和pre 指向的是同一个节点,说明此时删去的是 第一个元素。因为上一部q.next==null,这是只要把头结点指向他下一个节点即可。

如果p和pre不等,则直接删除p

分享到:
评论

相关推荐

    C语言-leetcode题解之19-remove-nth-node-from-end-of-list.c

    首先需要找到倒数第n个节点,然后进行删除操作,同时确保链表的完整性不被破坏。 5. 指针操作: 在C语言中,指针是非常重要的概念,用于存储变量的内存地址。通过指针,我们可以直接修改内存中的数据。在处理链表...

    LeetCode答案大全

    19. Remove Nth Node From End of List:移除链表的倒数第N个节点。这个问题可以通过双指针法来解决。 20. Valid Parentheses:判断给定的字符串是否是有效的括号字符串。 LeetCode的答案大全中整理的这些问题,...

    Leetcode答案(c++版)

    **1.2 Remove Nth Node From End of List (19)** - **问题描述**:给定一个链表,删除倒数第 n 个节点,并且返回链表的头结点。 - **解题思路**: - 使用双指针法,一个快指针先走 n 步,然后慢指针和快指针同时...

    leetcode怎么销号-leetcodeAns:leetcode问题的答案python

    本题要求移除倒数第n个点,进阶解法要求只遍历一遍完成。 我采用字典,将节点编号和节点存进字典里,这样遍历一遍记得到了所有,然后移除即可。 看了答案的一遍过滤的方法是用两个指针完成,让这两

    leetcode-cpp刷题

    - **2.2.7 Remove Nth Node From End of List** - 删除链表倒数第n个节点。 - 实现思路:使用快慢指针,快指针先走n步,当快指针到达尾部时,慢指针指向待删除节点的前一个节点。 - **2.2.8 Swap Nodes in Pairs...

    Leetcode代码以及解答(2)

    Remove Nth Node From End of List **知识点:** - **问题描述:** - 删除链表中倒数第 `n` 个节点。 - **解决方案分析:** - **双指针:** - 定义两个指针 `p1` 和 `p2`。 - 先让 `p2` 向前移动 `n` 步。 ...

Global site tag (gtag.js) - Google Analytics