栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

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

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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;
}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/876846.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号