[LeetCode-JAVA] Remove Duplicates from Sorted List II 최적화 버전

5279 단어 LeetCode
제목:
Given a sorted linked list, delete all nodes that have duplicate numbers, leaving only distinct numbers from the original list.
For example,Given  1->2->3->3->4->4->5 , return  1->2->5 .Given  1->1->1->2->3 , return  2->3 .
 
원시적인 사고방식: 앞의 지침을 보존한다. 이렇게 하면 중복될 때next로 새로운 위치를 직접 가리킬 수 있다. 주의해야 할 것은 시작할 때 중복이 있는지 추가 판단을 해야 잘못된 지침을 형성할 수 있다.
원본 코드:
public class Solution {
    public ListNode deleteDuplicates(ListNode head) {
        ListNode req = head;
        ListNode pre = head;
        
        //         
        while(head != null){
            head = head.next;   //       ,head  pre    
            if(head != null && pre.val == head.val){
                do{
                    head = head.next;
                }
                while(head!=null && head.val == pre.val);
                pre = head;
                req = head;
            }else break;    
        }
        //     ,pre   head       
        while(head != null){
            head = head.next;
            if(head!=null && pre.next.val == head.val){
                do{
                    head = head.next;
                }
                while(head!=null && head.val == pre.next.val);
                pre.next = head;
            }
            else pre = pre.next;            
        }
        
        return req;
    }
}

 
 
수정 사고방식: 가상 헤더를 만들 수 있고next는head를 가리키며 원시 코드의 초기 부분의 추가 판단을 최적화시킬 수 있다. 코드는 매우 간결하다.
수정 후 코드:
 
public class Solution {
    public ListNode deleteDuplicates(ListNode head) {
        ListNode dunmy = new ListNode(Integer.MIN_VALUE);
        dunmy.next = head;
        ListNode pre = dunmy;

        while(head != null){
            head = head.next;
            if(head!=null && pre.next.val == head.val){
                do{
                    head = head.next;
                }
                while(head!=null && head.val == pre.next.val);
                pre.next = head;
            }
            else pre = pre.next;            
        }
        
        return dunmy.next;
    }
}

좋은 웹페이지 즐겨찾기