描述
描述
给定一个用单链表表示的整数,然后把这个整数加一。
数据范围:链表长度满足 ,链表上每个节点的值满足 ,可以保证链表在非 0 的情况下没有前导零
例如输入{1,2,3}时,对应的输出为{1,2,4},转换过程如下图所示:
分析
在原链表上加1,需要向前进位,但单链表不能后退,所以先把链表反转,然后像两个链表相加求和(leetcode 2. 两数相加/)那样加一,最后再次反转链表就是答案。
直接在原链表上操作
import java.util.*;
public class Solution {
public ListNode plusOne (ListNode head) {
head = reverse(head);
int progress = 1;
ListNode cur = head;
while(progress == 1){
int num = cur.val