zoukankan      html  css  js  c++  java
  • Remove Duplicates from Sorted List leetcode java

    题目:

    Given a sorted linked list, delete all duplicates such that each element appear only once.

    For example,
    Given 1->1->2, return 1->2.
    Given 1->1->2->3->3, return 1->2->3.

    题解:

    这道题是经典的双指针问题,用两个指针一前一后指向链表。如果两个指针指向的值相等,那么就让第二个指针一直往后挪,挪到与第一个指针不同为止。然后让第一个指针的next指向第二个指针,两个指针同时往后挪,进行下面的操作。

    需要注意,当list的结尾几个node是重复的时候,例如1->2->3->3,那么ptr2会指向null,需要特殊处理,令ptr1.next = null,这样list尾部就不会丢。

    其他情况就不用特殊处理结尾了,因为结尾没有重复值,只须遍历就够了,不用特殊处理尾部。

    代码如下: 

     1     public ListNode deleteDuplicates(ListNode head) {
     2         if(head == null || head.next == null)
     3             return head;
     4         
     5         ListNode ptr1 = head;
     6         ListNode ptr2 = head.next;
     7         
     8         while(ptr2!=null){
     9             if(ptr1.val == ptr2.val){
    10                 ptr2 = ptr2.next;
    11                 if(ptr2==null)
    12                     ptr1.next = null;
    13             }else{
    14                 ptr1.next = ptr2;
    15                 ptr1 = ptr1.next;
    16                 ptr2 = ptr2.next;
    17             }
    18         }
    19 
    20         return head;
    21     }

  • 相关阅读:
    C-Lodop 非典型应用
    这里有个坑---js日期格式yyyy-MM-dd与yyyy/MM/dd
    这里有个坑---[NotMapped]不要忘了加
    这里有个坑---entity为null的问题
    数据库优化小技巧总结
    前端优化小技巧总结
    前端日志探讨二
    25.密码学知识-对称加密-2——2019年12月19日
    24.mongodb可视化工具部署——2019年12月19日
    22.Express框架——2019年12月19日
  • 原文地址:https://www.cnblogs.com/springfor/p/3862042.html
Copyright © 2011-2022 走看看