您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“Java如何實(shí)現(xiàn)兩數(shù)相加”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“Java如何實(shí)現(xiàn)兩數(shù)相加”這篇文章吧。
給出兩個 非空 的鏈表用來表示兩個非負(fù)的整數(shù)。其中,它們各自的位數(shù)是按照 逆序 的方式存儲的,并且它們的每個節(jié)點(diǎn)只能存儲 一位 數(shù)字。
如果,我們將這兩個數(shù)相加起來,則會返回一個新的鏈表來表示它們的和。
您可以假設(shè)除了數(shù)字 0
之外,這兩個數(shù)都不會以 0
開頭。
示例:
輸入:(2 -> 4 -> 3) + (5 -> 6 -> 4)輸出:7 -> 0 -> 8原因:342 + 465 = 807
標(biāo)簽:鏈表
將兩個鏈表看成是相同長度的進(jìn)行遍歷,如果一個鏈表較短則在前面補(bǔ)0,比如 987 + 23 = 987 + 023 = 1010
每一位計算的同時需要考慮上一位的進(jìn)位問題,而當(dāng)前位計算結(jié)束后同樣需要更新進(jìn)位值
如果兩個鏈表全部遍歷完畢后,進(jìn)位值為1,則在新鏈表最前方添加節(jié)點(diǎn)1
小技巧:對于鏈表問題,返回結(jié)果為頭結(jié)點(diǎn)時,通常需要先初始化一個預(yù)先指針pre,該指針的下一個節(jié)點(diǎn)指向真正的頭結(jié)點(diǎn)head。使用預(yù)先指針的目的在于鏈表初始化時無可用節(jié)點(diǎn)值,而且鏈表構(gòu)造過程需要指針移動,進(jìn)而會導(dǎo)致頭指針丟失,無法返回結(jié)果。
/**
* 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 pre = new ListNode(0);
ListNode cur = pre;
int carry = 0;
while(l1 != null || l2 != null) {
int x = l1 == null ? 0 : l1.val;
int y = l2 == null ? 0 : l2.val;
int sum = x + y + carry;
carry = sum / 10;
sum = sum % 10;
cur.next = new ListNode(sum);
cur = cur.next;
if(l1 != null)
l1 = l1.next;
if(l2 != null)
l2 = l2.next;
}
if(carry == 1) {
cur.next = new ListNode(carry);
}
return pre.next;
}
}
以上是“Java如何實(shí)現(xiàn)兩數(shù)相加”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。