leetcode第二题java_leetcode第二题

leetcode第二题

题目:

给定两个非空链表来表示两个非负整数。位数按照逆序方式存储,它们的每个节点只存储单个数字。将两数相加返回一个新的链表。

你可以假设除了数字 0 之外,这两个数字都不会以零开头。

源码(使用java语言)

/**

* definition for singly-linked list.

* public class listnode {

* int val;

* listnode next;

* listnode(int x) { val = x; }

* }

*/

class solution {

public listnode addtwonumbers(listnode l1, listnode l2) {

listnode result = new listnode(0);

listnode temp = result;

listnode temp1 = l1;

listnode temp2 = l2;

int x,y,sum=0;

while(temp1!=null||temp2!=null){

x = temp1==null?0:temp1.val;

y = temp2==null?0:temp2.val;

sum = sum+x+y;

temp.next = new listnode(sum%10);

sum = sum/10;//进位

temp = temp.next;

if(temp1!=null)

temp1 = temp1.next;

if(temp2!=null)

temp2 = temp2.next;

}

if(sum>0){temp.next = new listnode(1);}

return result.next;

}

}

此算法比较简单,在这里做出两点说明:

注释“进位”那一行个人觉得很神髓(或许又只是接触太少——大佬勿喷/拜托/拜托),每次循环之后如果超过十则进位,否则自动为零~

最后一个if语句,因为最终如果进位,那么新增位上一定是1,所以这里直接赋予常量

ps:还在学习之中,如果有写的不得当的地方还请多多提醒/抱拳/抱拳

希望与广大网友互动??

点此进行留言吧!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值