摘要:多位數(shù)加多位數(shù),反轉(zhuǎn)鏈表轉(zhuǎn)化整數(shù),如果整數(shù)相加,可能會溢出,此方法行不通。直接進行位數(shù)運算,兩鏈表每取出一個就做運算,將結(jié)果放入到新鏈表中。求和運算會出現(xiàn)額外的進位一般進位與最高位進位兩種情況。兩位數(shù)取模運算。
Time:2019/4/2題目二:ADD Two Numbers
Title: ADD Two Numbers
Difficulty: medium
Author:小鹿
公眾號:一個不甘平凡的碼農(nóng)。
You are given two non-empty linked lists representing two non-negative integers. The digits are stored in reverse order and each of their nodes contain a single digit. Add the two numbers and return it as a linked list.
You may assume the two numbers do not contain any leading zero, except the number 0 itself.
Example:
Input: (2 -> 4 -> 3) + (5 -> 6 -> 4) Output: 7 -> 0 -> 8 Explanation: 342 + 465 = 807.
Solve:
1)觀察 Example 規(guī)律,關(guān)聯(lián)到鏈表,用一個帶頭的鏈表存儲。2)多位數(shù)加多位數(shù),反轉(zhuǎn)鏈表轉(zhuǎn)化整數(shù),如果整數(shù)相加,可能會溢出,此方法行不通。
3)直接進行位數(shù)運算,兩鏈表每取出一個就做運算,將結(jié)果放入到新鏈表中。
1)一個鏈表比另一個鏈表長;2)其中一個鏈表為 null。
3)求和運算會出現(xiàn)額外的進位(一般進位與最高位進位兩種情況)。
1)遍歷鏈表之前,要定義一個哨兵結(jié)點、臨時結(jié)點、存儲計算結(jié)果的結(jié)點、進位標志;2)開始遍歷數(shù)據(jù),判斷當前結(jié)點是否為 null,為 null 就用 0 代替,否則取出數(shù)值;
3)求和(加 carray 進位),判斷是否進位?記錄進位值;
4)求模取余,計算兩位數(shù)的各位數(shù)存儲到鏈表中,指針向后移動;
5)判斷結(jié)點是否為 null,繼續(xù)遍歷(如果鏈表 l2 比 l1 短,沒有下一結(jié)點只能返回本身下次處理當做 null 處理)
6) 退出 while 循環(huán)勿忘最高位滿位情況,carray 還存放著 1,所以判斷最高位是否需要進位,存放到鏈表最后
/** * 性能分析: * 1)遍歷整個鏈表,時間復雜度為 O(n)。 * 2)需要額外的 n 大小的空間存儲 計算結(jié)果結(jié)點,空間復雜度為 O(n)。 */ var addTwoNumbers = function(l1, l2) { //定義哨兵結(jié)點 let head = new ListNode("head"); let current = head;//臨時指針 //存儲計算后的鏈表 let sumNode = head; //定義進位變量 let carray = 0; //開始遍歷兩個鏈表取數(shù)據(jù),判斷鏈表是否為 null while(l1 !== null || l2 !== null){ //判斷取數(shù)據(jù)的鏈表是否為nulL,為 null 就用 0 替換 let num1 = 0; let num2 = 0; if(l1 == null){ num1 = 0; }else{ num1 = l1.val; } if(l2 == null){ num2 = 0; }else{ num2 = l2.val; } // let num1 = l1 == null ? 0 : l1.val; // let num2 = l2 == null ? 0 : l2.val; //計算取出的兩個數(shù)值的和用于判斷是否滿進位,如果滿 10,carray 需要記錄進位,默認為 0 let sum = num1 + num2 + carray; //判斷是否需要存儲進位值 1 if(sum > 9){ carray = 1; }else{ carray = 0; } //carray = sum > 9 ? 1 : 0; //將兩數(shù)之和相加[取模(取余運算)]添加到 sumNode 新鏈表中,一次排列 current.next = new ListNode(sum % 10) //將指針指向下一鏈表結(jié)點 current = current.next; //繼續(xù)遍歷鏈表中的數(shù)據(jù),判斷下一結(jié)點是否為 null if(l1 !== null){ l1 = l1.next; }else{ //如果鏈表 l1 比 l2 短,沒有下一結(jié)點只能返回本身下次處理當做 null 處理 l1 = l1; } if(l2 !== null){ l2 = l2.next; }else{ //如果鏈表 l2 比 l1 短,沒有下一結(jié)點只能返回本身下次處理當做 null 處理 l2 = l2; } // l1 為不為 null 才滿足條件 // l1 = l1 ? l1.next : l1; // l2 = l2 ? l2.next : l2; } //最高位滿位情況,carray 還存放著 1,所以判斷最高位是否需要進位 if(carray === 1){ //有哨兵的,所以需要 next 才能存放下一結(jié)點 current.next = new ListNode(1); } //返回哨兵結(jié)點之后的鏈表 return head.next; }
var addTwoNumbers = function(l1, l2) { //定義哨兵結(jié)點 let head = new ListNode("head"); let current = head;//臨時指針 //存儲計算后的鏈表 let sumNode = head; //定義進位變量 let carray = 0; //開始遍歷兩個鏈表取數(shù)據(jù),判斷鏈表是否為 null while(l1 !== null || l2 !== null){ //判斷取數(shù)據(jù)的鏈表是否為nulL,為 null 就用 0 替換 let num1 = l1 == null ? 0 : l1.val; let num2 = l2 == null ? 0 : l2.val; //計算取出的兩個數(shù)值的和用于判斷是否滿進位,如果滿 10,carray 需要記錄進位,默認為 0 let sum = num1 + num2 + carray; //判斷是否需要存儲進位值 1 if(sum > 9){ carray = 1; }else{ carray = 0; } //carray = sum > 9 ? 1 : 0; //將兩數(shù)之和相加[取模(取余運算)]添加到 sumNode 新鏈表中,一次排列 current.next = new ListNode(sum % 10) //將指針指向下一鏈表結(jié)點 current = current.next; //繼續(xù)遍歷鏈表中的數(shù)據(jù),判斷下一結(jié)點是否為 null l1 為不為 null 才滿足條件 l1 = l1 ? l1.next : l1; l2 = l2 ? l2.next : l2; } //最高位滿位情況,carray 還存放著 1,所以判斷最高位是否需要進位 if(carray === 1){ //有哨兵的,所以需要 next 才能存放下一結(jié)點 current.next = new ListNode(1); } //返回哨兵結(jié)點之后的鏈表 return head.next; }
1、 l1 = l1 ? l1.next : l1 代表的是 l1 不等于 null 會去 l1.next 的值。2、用到哨兵思想,所以注意當前的指針指向。
3、兩位數(shù)取模運算。
三位數(shù)怎么取得各個位置上的數(shù)字呢?(水仙花數(shù))答:
//移動小數(shù)點向前一位,得到小數(shù)點后一位 個位:a = 123 % 10 = 3 //移動小數(shù)點向前兩位,得到小數(shù)點后兩位,除以10取整 十位:b = parseInt((123 % 100) / 10) //移動小數(shù)點向前三位,得到小數(shù)點后三位,除以100取整 百位::c = parseInt((123 % 1000) / 100) //依次類推.....
歡迎一起加入到 LeetCode 開源 Github 倉庫,可以向 me 提交您其他語言的代碼。在倉庫上堅持和小伙伴們一起打卡,共同完善我們的開源小倉庫!
Github:https://github.com/luxiangqia...
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/103189.html
摘要:更新之前說感覺優(yōu)秀答案的最后三行可以用尾遞歸優(yōu)化不知道尾遞歸的小伙伴可以點這里,仔細想了一下,并不能。尾遞歸的實現(xiàn),往往需要改寫遞歸函數(shù),確保最后一步只調(diào)用自身。 上周日就想寫vue.nextTick的源碼分析,可是總是不知道從哪兒下手,今天有時間,先把leetcode第二題補了,感覺這道題還挺簡單的 一、題目 兩數(shù)相加: 給出兩個 非空 的鏈表用來表示兩個非負的整數(shù)。其中,它們各自...
摘要:給出兩個非空的鏈表用來表示兩個非負的整數(shù)。如果,我們將這兩個數(shù)相加起來,則會返回一個新的鏈表來表示它們的和。需要考慮到兩個鏈表長度不同時遍歷方式鏈表遍歷完成時最后一位是否需要進一位。 ?給出兩個 非空 的鏈表用來表示兩個非負的整數(shù)。其中,它們各自的位數(shù)是按照 逆序 的方式存儲的,并且它們的每個節(jié)點只能存儲 一位 數(shù)字。如果,我們將這兩個數(shù)相加起來,則會返回一個新的鏈表來表示它們的和。 ...
摘要:給出兩個非空的鏈表用來表示兩個非負的整數(shù)。如果,我們將這兩個數(shù)相加起來,則會返回一個新的鏈表來表示它們的和。需要考慮到兩個鏈表長度不同時遍歷方式鏈表遍歷完成時最后一位是否需要進一位。 ?給出兩個 非空 的鏈表用來表示兩個非負的整數(shù)。其中,它們各自的位數(shù)是按照 逆序 的方式存儲的,并且它們的每個節(jié)點只能存儲 一位 數(shù)字。如果,我們將這兩個數(shù)相加起來,則會返回一個新的鏈表來表示它們的和。 ...
摘要:步驟遍歷數(shù)組數(shù)據(jù),將根據(jù)下標和元素值存放到散列表中。目標值減去數(shù)組元素差值并在散列表中查找。測試法三一遍哈希表算法思路遍歷目標值減去數(shù)組元素的差值同時判斷該值在散列表中是否存在差值,如果存在,則返回否則將數(shù)據(jù)加入到散列表中。 Time:2019/4/1Title:Two SumDifficulty: simpleAuthor:小鹿 題目一:Two Sum Given an array ...
摘要:月下半旬攻略道題,目前已攻略題。目前簡單難度攻略已經(jīng)到題,所以后面會調(diào)整自己,在刷算法與數(shù)據(jù)結(jié)構(gòu)的同時,攻略中等難度的題目。 Create by jsliang on 2019-07-30 16:15:37 Recently revised in 2019-07-30 17:04:20 7 月下半旬攻略 45 道題,目前已攻略 100 題。 一 目錄 不折騰的前端,和咸魚有什么區(qū)別...
閱讀 2882·2021-10-08 10:12
閱讀 3978·2021-09-22 15:45
閱讀 2568·2019-08-30 15:52
閱讀 2638·2019-08-29 18:44
閱讀 2657·2019-08-29 12:37
閱讀 1168·2019-08-26 13:36
閱讀 2572·2019-08-26 13:34
閱讀 1487·2019-08-26 12:20