码迷,mamicode.com
首页 > 其他好文 > 详细

11/4 <LinkedList>

时间:2019-11-04 13:36:35      阅读:81      评论:0      收藏:0      [点我收藏+]

标签:tno   dde   ++   过程   solution   reverse   ebe   判断   设置   

328. Odd Even Linked List

“穿针引线”

1. odd指针穿奇数位

2.even指针穿偶数位

3.用evenHead记录第一个偶数位节点,最后用odd连接evenHead

注意判断空节点以及一个节点的情况。

class Solution {
    public ListNode oddEvenList(ListNode head) {
        if(head == null || head.next == null)
            return head;
        
        ListNode odd = head, even = head.next, evenHead = even;
        
        while(even != null && even.next != null){
            odd.next = even.next;
            odd = odd.next;
            even.next = odd.next;
            even = even.next;
        }
        odd.next = evenHead;
        return head;
    }
}

92. Reverse Linked List II

1. 对于链表的问题,根据以往的经验一般都是要建一个dummy node,连上原链表的头结点,这样的话就算头结点变动了,我们还可以通过dummy->next来获得新链表的头结点。

每一步将cur后面的节点设置为temp节点,目的是为了把temp节点交换到pre.next的位置。这样的过程需要保持n-m次。

class Solution {
    public ListNode reverseBetween(ListNode head, int m, int n) {
        ListNode dummy = new ListNode(0);
        dummy.next = head;
        ListNode pre = dummy;
        ListNode cur = head;
        
        if(head == null || head.next == null)
            return head;

        for(int i = 1; i < m; i++){
            pre = pre.next;
            cur = pre.next;
        }
          
        
        for(int i = m; i < n; i++){
            ListNode temp = cur.next;
            cur.next = temp.next;
            temp.next = pre.next;
            pre.next = temp;
        }
        return dummy.next;
    }
}

 

 

11/4 <LinkedList>

标签:tno   dde   ++   过程   solution   reverse   ebe   判断   设置   

原文地址:https://www.cnblogs.com/Afei-1123/p/11791445.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!