改进双指针-哨兵+双指针

删除有序链表中重复出现的元素

http://www.nowcoder.com/questionTerminal/71cef9f8b5564579bf7ed93fbe0b2024

/**
 * struct ListNode {
 *    int val;
 *    struct ListNode *next;
 * };
 */

class Solution {
public:
    /**
     * 
     * @param head ListNode类 
     * @return ListNode类
     */
    ListNode* deleteDuplicates(ListNode* head) {
        // write code here
        if( nullptr==head || nullptr==(head->next) )
        {
            return head;
        }
        //改进的“双指针”
        ListNode * ret=new ListNode(-1);
        ListNode * pre=ret;
        ret->next=head;

        ListNode * Low=head;
        ListNode * Fast=head;
        while( nullptr!=Fast )
        {
            Fast=Fast->next;
            if( nullptr==Fast )
            {
                break;
            }
            int tag=0;

            while( nullptr!=Fast && Low->val!=Fast->val )
            {
                pre=pre->next;
                Low=Low->next;
                Fast=Fast->next;
            }
            while( nullptr!=Fast && Low->val == Fast->val )
            {
                Fast=Fast->next;
                tag=1;
            }

            if( tag )
            {
                pre->next=Fast;
                ListNode * temp=Low;
                Low=Fast;
                while( temp!=Fast )
                {
                    ListNode * del=temp;
                    temp=temp->next;
                    delete del;
                }

            }


            if( nullptr==Fast )
            {
                break;
            }

        }


        ListNode * temp=ret;
        ret=ret->next;
        delete temp;
        return ret;

    }
};
全部评论

相关推荐

11-11 14:21
西京学院 C++
无敌混子大王:首先一点,不管学校层次怎么样,教育经历放在第一页靠上位置,第一页看不到教育经历,hr基本直接扔掉了
点赞 评论 收藏
分享
10-11 17:45
门头沟学院 Java
走吗:别怕 我以前也是这么认为 虽然一面就挂 但是颇有收获!
点赞 评论 收藏
分享
1 收藏 评论
分享
牛客网
牛客企业服务