题解 | #删除链表中重复的结点#

删除链表中重复的结点

http://www.nowcoder.com/practice/fc533c45b73a41b0b44ccba763f866ef

新建头结点,处理首元素特例!

class Solution {
public:
    ListNode* deleteDuplication(ListNode* pHead) {
        
        
        // 这个方法问题有点大,卡死在第一个元素
        // 解决方案:新建头结点
        ListNode *head = (ListNode *)malloc(sizeof(ListNode));
        ListNode *pre = head;
        head->next = pHead;
        ListNode *cur = pHead;
        
        int flag = -1;
        
        // 有一个特殊情况,第一个元素是多个,这个无法解决
        while(cur != NULL){
            if(cur->next == NULL){
                break;
            }
            
            if(cur->val == cur->next->val){
                cur = cur->next;
                flag = 1;
            }else{
                cur = cur->next;
                
                if(flag == 1){
                    pre->next = cur;
                    flag = -1;
                }else{
                    pre = pre->next;
                }
            }
            
            // 如果flag没被改变,说明后面所有元素一致,需要处理
            if(flag == 1){
               pre->next = cur->next;
            }
        }
        
        return head->next;
    }
};
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-02 17:28
25届每天都在焦虑找工作的事情0offer情绪一直很低落硬撑着面了一个岗位岗位有应酬的成分面试的时候hr给我出各种场景题问的问题比较犀利 有点压力面的感觉感觉有点回答不上来本来就压抑的情绪瞬间爆发了呢一瞬间特别想哭觉得自己特别没用没绷住掉眼泪了事后想想觉得自己挺有病的 真的破大防了
喜欢唱跳rap小刺猬...:我觉得没关系吧,之前有一次面试leader给我压力面,我顶住了压力,结果入职的时候发现组里氛围很差,果断跑路。其实从面试就能大概看出组的情况,面试体验好的组倒是不一定好,但是面试体验不好的组。。。就很难说
点赞 评论 收藏
分享
仁者伍敌:牛子这些人还会点一个自动回复,boss都不带回复的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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