您的位置:首页 > 其它

<LeetCode OJ> 83. Remove Duplicates from Sorted List

2016-01-08 15:28 267 查看


83. Remove Duplicates from Sorted List

My Submissions

Question

Total Accepted: 94387 Total
Submissions: 264227 Difficulty: Easy

题目意思:现在有一个已经排好顺序的链表,删除所有重复的节点,使每个节点都只出现一次!
Given a sorted linked list, delete all duplicates such that each element appear only once.
For example,

Given
1->1->2
, return
1->2
.

Given
1->1->2->3->3
, return
1->2->3
.

Subscribe to see which companies asked this question

Hide Tags
Linked List

/**
 * 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==NULL)
            return NULL;
        ListNode* preNode=NULL;
        ListNode* curNode=head;
        ListNode* delNode=NULL;
        while(curNode)
        {
            if(preNode && preNode->val==curNode->val)
            {
                preNode->next=curNode->next;
                delNode=curNode;
                curNode=curNode->next;
                delete delNode;
                delNode=NULL;
                continue;
            }
            preNode=curNode;
            curNode=curNode->next;
        }
        
        return head;
    }
};


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