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

删除链表中重复的结点

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;
    }
};
全部评论

相关推荐

01-19 12:48
门头沟学院 C++
只想搞钱的鸽子很喜欢...:混账是很多的,还有那些在自己风华正茂的年纪说风凉话讥讽那些下岗前员工的。这些人都是现在职场环境这么烂的帮凶
点赞 评论 收藏
分享
2025-12-19 19:02
西安交通大学 Java
程序员牛肉:双九,而且还是西交这种比较好的985九没必要再投日常了。你投中小厂,人家会觉得你学历这么顶还面试肯定是海投的,过了你也不去。所以不约你了。 直接准备暑期实习就好,现在你可以面试。但是目的不再是去日常实习了,而是熟悉面试节奏。 后续把精力放到八股,算法和AI知识上。抽空把自己这两个项目换了,怎么选项目可以看看我主页写的文章。 你学历不错的,不要焦虑
那些拿到大厂offer的...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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