您的位置:首页 > Web前端 > Node.js

Delete Node in a Linked List

2017-04-11 09:10 253 查看
Write a function to delete a node (except the tail) in a singly linked list, given only access to that node.

Supposed the linked list is 1 -> 2 -> 3 -> 4 and you are given the third node with value 3, the linked list should become 1 -> 2 -> 4 after calling your function.

直接将后一个数据复制到前面。

方法1: 这个实现方式较为繁琐。

class Solution {
public:
void deleteNode(ListNode* node) {
if(node==NULL)
return;
while(node->next!=NULL){
node->val = node ->next ->val;
if(node ->next ->next == NULL){
free(node->next);
node->next = NULL;
break;
}
else
node = node->next;
}
return ;
}
};


方法2:简便实现方式,直接复制整体即可。

class Solution {
public:
void deleteNode(ListNode* node) {
*node = *node->next;
}
};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: