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

Posted 刘Java

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode Java刷题笔记—2. 两数相加相关的知识,希望对你有一定的参考价值。

2. 两数相加

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

中等难度,这道题和面试题 02.05. 链表求和是同一道题。这道题,我们需要维护一个进位变量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;

以上是关于LeetCode Java刷题笔记—2. 两数相加的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode刷题笔记-数据结构-day10

LeetCode刷题笔记-数据结构-day10

leetcode 刷题--- 两数相加

leetcode刷题2:两数相加add_two_numbers

Leetcode刷题100天—2. 两数相加( 链表)—day60

Leetcode刷题100天—2. 两数相加( 链表)—day60