您的位置:首页 > 其它

Leedcode:remove duplicates from sorted list 2

2015-07-21 19:05 316 查看
给定一个有序的单链表,删除所有重复的节点,只剩下不重复的节点;

例如1->2->2->3->4->5

返回1->3->4->5

递归实现:

/**

* Definition for singly-linked list.

* struct ListNode {

* int val;

* ListNode *next;

* ListNode(int x) : val(x), next(NULL) {}

* };

*/

class Solution {

public:

ListNode* deleteDuplicates(ListNode* head) {

if(!head || !head->next) return head;

ListNode *p = head->next;

if(head->val == p->val){

while(p && head->val == p->val){

ListNode *tmp = p;

p = p->next;

delete tmp;

}

delete head;

return deleteDuplicates(p);

}else{

head->next = deleteDuplicates(head->next);

return head;

}

}

};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: