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;
}