LeetCode Java刷题笔记—2. 两数相加

给你两个非空的链表,表示两个非负的整数。它们每位数字都是按照 逆序 的方式存储的,并且每个节点只能存储一位数字。请你将两个数相加,并以相同形式返回一个表示和的链表。

中等难度,这道题和是同一道题。这道题,我们需要维护一个进位变量t,新建一个当前节点,值为两个链表节点的和%10,即取个位数,然后t再除以10,此时t变成了十位数,参与下一次计算。通过这种方式,可以实现逆序的结果输出。

public ListNode addTwoNumbers( ListNode l1, ListNode l2 ){
          
   

   ListNode dummyHead = new ListNode( -1 ), pre = dummyHead;
   //进位变量t
   int t = 0;
   while( l1 != null || l2 != null || t != 0 ){
          
   
      if( l1 != null ){
          
   
         t += l1.val;
         l1 = l1.next;
      }
      if( l2 != null ){
          
   
         t += l2.val;
         l2 = l2.next;
      }
      //新建节点,值为当前节点对10取模,即获取个位数
      pre.next = new ListNode( t % 10 );
      pre = pre.next;
      //t保留十位数
      t /= 10;
   }

   return dummyHead.next;
}
经验分享 程序员 微信小程序 职场和发展