zoukankan      html  css  js  c++  java
  • LeetCode--Remove Nth Node From End of List

    Question:

    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.

    解题思路

    尽量用一遍扫描解决问题,我就想在扫描过程中,每个节点都用一个新的指针指向,然后保存到一个数组中,数组就可以用O(1)的时间定位,也只是扫描了一遍。

    数组中指针的个数就是节点的个数,然后根据删除的节点的位置,移动相应的指针即可。

    实现代码

    #include <iostream>
    #include <vector>
    
    using namespace std;
    
    
    //Definition for singly-linked list.
    struct ListNode {
         int val;
         ListNode *next;
         ListNode(int x) : val(x), next(NULL) {}
    };
    
    class Solution {
    public:
        ListNode* removeNthFromEnd(ListNode* head, int n) {
            ListNode* p = head;
            if (p == NULL)
                return head;
            else
                vec.push_back(p);
            while(p->next != NULL) {
                p = p->next;
                ListNode* new_ptr = p;
                vec.push_back(new_ptr);
            }
            int cur = vec.size() - n;
            if (cur - 1 >= 0) {
                if (cur + 1 <= vec.size() - 1) {
                    vec[cur - 1 ]->next = vec[cur + 1];
                    } else {
                    vec[cur - 1]->next = NULL;
                }
            } else {
                if (cur + 1 <= vec.size() - 1) {
                    head = vec[cur + 1];
                } else
                    head  = NULL;
            }
            return head;
        }
    private:
        vector<ListNode*> vec;
    };
    
    
    int main() {
        Solution* solution = new Solution();
        ListNode* node1 = new ListNode(1);
        ListNode* node2 = new ListNode(2);
        ListNode* node3 = new ListNode(3);
        ListNode* node4 = new ListNode(4);
        ListNode* node5 = new ListNode(5);
    
        node1->next = node2;
        node2->next = node3;
        node3->next = node4;
        node4->next = node5;
    
        ListNode* head = solution->removeNthFromEnd(node1, 2);
        while(head != NULL) {
            cout << head->val << endl;
            head = head->next;
        }
    
        return 0;
    }
    
  • 相关阅读:
    tuple元组
    list列表
    OS模块
    time模块/datetime模块/calendar模块
    Codeforces Round #196 (Div. 2)
    【HDU 2853】 KM算法
    【HDU1914 The Stable Marriage Problem】稳定婚姻问题
    【HDU4585 Shaolin】map的经典运用
    【HDU4578 Transformation】线段树
    【HDU4632 Palindrome subsequence】区间dp
  • 原文地址:https://www.cnblogs.com/zhonghuasong/p/6436183.html
Copyright © 2011-2022 走看看