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

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

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;

    }
};
全部评论

相关推荐

06-20 17:42
东华大学 Java
凉风落木楚山秋:要是在2015,你这简历还可以月入十万,可惜现在是2025,已经跟不上版本了
我的简历长这样
点赞 评论 收藏
分享
半解316:内容充实,细节需要修改一下。 1,整体压缩为一页。所有内容顶格。 2,项目描述删除,直接写个人工作量 修改完之后还需要建议,可以私聊
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-15 17:24
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务