zoukankan      html  css  js  c++  java
  • LinkList 专题之三

    Rotate List

    Given a list, rotate the list to the right by k places, where k is non-negative.

    For example:
    Given 1->2->3->4->5->NULL and k = 2,
    return 4->5->1->2->3->NULL.

    /**
     * Definition for singly-linked list.
     * public class ListNode {
     *     int val;
     *     ListNode next;
     *     ListNode(int x) { val = x; }
     * }
     */
    public class Solution {
        public ListNode rotateRight(ListNode head, int k) {
            ListNode first=head;
            ListNode slow=head;
             ListNode pre=head;
            if(head==null||head.next==null||k==0){
                return head;
            }
            int count=1;
            while(pre.next!=null){
                pre=pre.next;
                count++;
            }
           
            if(k==count||k%count==0){ //注意k>list AND k为list的倍数
                return head;
            }
            k=k%count;
            for(int i=0;i<k;i++){
                first=first.next;
            }
            while(first!=null){
                slow=slow.next;
                first=first.next;
            }
            ListNode res=slow;
            while(slow.next!=null){
                slow=slow.next;
            }
            ListNode temp=head;
            while(temp!=res){
                slow.next=temp;
                temp=temp.next;
                slow=slow.next;
            }
            slow.next=null;
            return res;
        }
    }

    time O(n)

    Remove Duplicates from Sorted List

    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.

    分析:两个指针遍历pre和current,一前一后

    /**
     * Definition for singly-linked list.
     * public class ListNode {
     *     int val;
     *     ListNode next;
     *     ListNode(int x) { val = x; }
     * }
     */
    public class Solution {
        public ListNode deleteDuplicates(ListNode head) {
             if(head==null||head.next==null){
                return head;
            }
           ListNode newhead=new ListNode(0);
           ListNode res=newhead;
           ListNode pre=head;
           ListNode current=head.next;
           while(current!=null){
               if(pre.val!=current.val){
                   newhead.next=new ListNode(pre.val);
                   pre=pre.next;
                   current=current.next;
                   newhead=newhead.next;
               }else{
                   current=current.next;
                   pre=pre.next;
               }
           }
              newhead.next=pre;
              return res.next;
        }
    }

    Remove Duplicates from Sorted List

    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.

    分析:加一个可识别的flag去掉重复元素以及一个特例[1,1]or[2,2]....返回为null

    /**
     * Definition for singly-linked list.
     * public class ListNode {
     *     int val;
     *     ListNode next;
     *     ListNode(int x) { val = x; }
     * }
     */
    public class Solution {
        public ListNode deleteDuplicates(ListNode head) {
            if(head==null||head.next==null){
                return head;
            }
           ListNode newhead=new ListNode(0);
           ListNode res=newhead;
           ListNode pre=head;
           ListNode current=head.next;
           if(pre.val==current.val&&current.next==null){
               return null;
           }
           boolean flag=true;
           while(current!=null){
               if(pre.val!=current.val&& flag==true){
                   newhead.next=new ListNode(pre.val);
                   pre=pre.next;
                   current=current.next;
                   newhead=newhead.next;
               }else if(pre.val!=current.val&& flag==false){
                   current=current.next;
                   pre=pre.next;
                   flag=true;
               }else if(pre.val==current.val){
                   current=current.next;
                   pre=pre.next;
                   flag=false;
               }
           }
           if(flag==true){
               newhead.next=pre;
           }
           return res.next;
        }
    }

    Partition List

    Given a linked list and a value x, partition it such that all nodes less than x come before nodes greater than or equal to x.

    You should preserve the original relative order of the nodes in each of the two partitions.

    For example,
    Given 1->4->3->2->5->2 and x = 3,
    return 1->2->2->4->3->5.

    分成两个链表

    /**
     * Definition for singly-linked list.
     * public class ListNode {
     *     int val;
     *     ListNode next;
     *     ListNode(int x) { val = x; }
     * }
     */
    public class Solution {
        public ListNode partition(ListNode head, int x) {
            ListNode small=new ListNode(0);
            ListNode big=new ListNode(0);
            ListNode b=big;
            ListNode res= small;
            if(head==null||head.next==null){
                return head;
            }
            ListNode temp=head;
            while(temp!=null){
                if(temp.val<x){
                  small.next=temp;
                  small=small.next;
                  temp=temp.next;
                }else{
                 big.next= temp;
                 big=big.next;
                 temp=temp.next;
                }
            }
            big.next=null;
            if(b.next!=null){
                small.next=b.next;
            }
            return res.next;
        }
    }
  • 相关阅读:
    最近有人说我欺骗消费者,今天来一波视频分享
    前端 Java Python等资源合集大放送
    dubbo源码学习(四):暴露服务的过程
    dubbo源码学习(二) : spring 自定义标签
    Dubbo多注册中心和Zookeeper服务的迁移
    线程各种状态转换分析
    java并发之同步辅助类CountDownLatch
    工作5年的Java程序员,才学会阅读源码,可悲吗?
    【阿里面试系列】Java线程的应用及挑战
    「阿里面试系列」搞懂并发编程,轻松应对80%的面试场景
  • 原文地址:https://www.cnblogs.com/joannacode/p/4570779.html
Copyright © 2011-2022 走看看