zoukankan      html  css  js  c++  java
  • leetcode[82] Remove Duplicates from Sorted List II

    给定一个有序链表,删除相同值的节点。例如

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

    我是新建一个ans链表,来存链表中distinct的值。不知道这样符合要求不。

    判断当前的值不等于前面一个也不等于后面一个那么就是符合条件的节点之一。

    /**
     * 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 || head->next == NULL) return head;
            ListNode *ans = new ListNode(0);
            ListNode *pre = ans;
            ListNode *now = head->next;
            ListNode *last = head;
            if (now && now->val != last->val) // 第一次要先判断,因为now从第二个节点开始
            {
                ListNode *tmp = new ListNode(last->val);
                pre->next = tmp;
                pre = pre->next;
            }
            while(now)
            {
                if ((now -> next == NULL || now->next && now->val != now->next->val) && now->val != last->val)
                {
                    ListNode *tmp = new ListNode(now->val);
                    pre->next = tmp;
                    pre = pre->next;
                    now = now->next;
                    last = last->next;
                    continue;
                }
                now = now->next;
                last = last->next;
            }
            head = ans->next;
            delete(ans);
            return head;
        }
    };

    因为我是另外开辟的,所以我还看了原链表中操作的。这个不错:

    用pre和now去删除节点,由于头节点也有可能删除,因此先建一个Head节点连头节点。

    pre从Head开始,用now去判断是否重复。

    如果重复,循环到下一个不同元素之前,把之间的相同元素直接跳过。

    再向前移动pre和now指针。

    /**
     * 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) {
            ListNode *pre,*now,*Head;
            if(!head||!head->next)return head;
            Head=new ListNode(-1);
            Head->next=head;
            pre=Head;
            now=head;
            while(now&&now->next)
            {
                if(now->val == now->next->val)
                {
                    while(now->next && now->val == now->next->val)
                    {
                        now=now->next;
                    }
                    pre->next=now->next;
                    now=now->next;
                }
                else 
                {
                    pre=now;
                    now=now->next;
                }
            }
            head=Head->next;
            delete(Head);
            return head;
        }
    };
  • 相关阅读:
    至理明言100个经典句子
    ASP操作cookies的方法
    Recordset属性与方法
    VB.NET下用FSO(文件系统对象模型)实现获取硬盘信息
    诺基亚10个不为人知的秘密
    JavaScript的常用事件/方法/特效
    javascript常用方法
    C#操作xml
    URL重写
    数据库之间的区别
  • 原文地址:https://www.cnblogs.com/higerzhang/p/4104748.html
Copyright © 2011-2022 走看看