leetcode369- Plus One Linked List- medium

Given a non-negative integer represented as non-empty a singly linked list of digits, plus one to the integer.

You may assume the integer do not contain any leading zero, except the number 0 itself.

The digits are stored such that the most significant digit is at the head of the list.

Example:

Input:
1->2->3

Output:
1->2->4

 

和+1数组有点像,关键要知道最多只要记录一串X9999就够了,前面的都是浮云,如果出现小于9的数字就相当于屏障,再也影响不到它之前的了。

最后这串被记录下来的,每个digit都做 digit = (digit + 1) % 10的操作。如果最前面的X也是9,那说明其实你整串肯定都是9999999,否则如89999不可能会最后存下来的第一个是9的。这个时候特殊还要再加一个1在最前头。

关于怎么记录有两种方法:

1.O(n) 空间:用一个stack。存下来后一个个吐回去

2.O(1)空间:用一个ListNode,只要记下最前面的X即可, 因为可以调用next不断向后遍历。

细节:1.小心99999多加一个点的问题。

 

实现1,用stack:

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
class Solution {
    public ListNode plusOne(ListNode head) {
        Stack<ListNode> stack = new Stack<>();
        ListNode dummy = new ListNode(0);
        dummy.next = head;
        while (head != null) {
            if (head.val != 9) {
                stack.clear();
            }
            stack.push(head);
            head = head.next;
        }
        ListNode crt = null;
        while (!stack.isEmpty()) {
            crt = stack.pop();
            crt.val = (crt.val + 1) % 10;
        }
        if (crt != null && crt.val == 0) {
            ListNode newN = new ListNode(1);
            newN.next = dummy.next;
            dummy.next = newN;
        }
        return dummy.next;
    }
}

 

实现2,用指针:

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
class Solution {
    public ListNode plusOne(ListNode head) {
        Stack<ListNode> stack = new Stack<>();
        ListNode dummy = new ListNode(0);
        dummy.next = head;
        ListNode change = head;
        
        // find the start point of those node that need change
        while (head != null) {
            if (head.val != 9) {
                change = head;
            }
            head = head.next;
        }
        
        // for the special case of 99999999...
        if (change.val == 9) {
            ListNode newN = new ListNode(1);
            newN.next = change;
            dummy.next = newN;
        }
        
        // make the add one change
        while (change != null) {
            change.val = (change.val + 1) % 10;
            change = change.next;
        }
        
        return dummy.next;
    }
}

 

posted @ 2017-12-04 14:17  jasminemzy  阅读(191)  评论(0编辑  收藏  举报