leetcode369. 给单链表加一

用一个 非空 单链表来表示一个非负整数,然后将这个整数加一。

你可以假设这个整数除了 0 本身,没有任何前导的 0。

这个整数的各个数位按照 高位在链表头部、低位在链表尾部 的顺序排列。

示例:

输入: [1,2,3]
输出: [1,2,4]

思路:

help():计算本位的数字,然后返回进位(0或1)

plusOne():因为help方法无法判断自己是否是最高位,所以在本方法中做一下处理。如果有进位,就再加一位最高的1即可。

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
class Solution {
    public ListNode plusOne(ListNode head) {
        int up=help(head);
        if(up==1){
            ListNode ans=new ListNode(1);
            ans.next=head;
            return ans;
        }
        return head;
    }
    
    public int help(ListNode head){
        int up=head.next==null?1:help(head.next);
        head.val+=up;
        up=(head.val)/10;
        head.val%=10;
        return up;
    }
}

 

©️2020 CSDN 皮肤主题: 书香水墨 设计师:CSDN官方博客 返回首页