日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

LeetCode:2. 两数相加(中等)

發(fā)布時間:2025/3/15 编程问答 23 豆豆
生活随笔 收集整理的這篇文章主要介紹了 LeetCode:2. 两数相加(中等) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

2. 兩數(shù)相加(中等)

  • 題目:
  • 解題思路:
  • 源碼:
  • 踩坑點:

題目:

解題思路:

把倆個鏈表對應位相加,如果大于等于10,對10取余,小于10,直接得到這一位

解題過程存在這樣幾個問題:
1、進行循環(huán)時,倆個鏈表長度不相等;9876 + 543
2、倆個鏈表的數(shù)相加時,長度大于倆個鏈表中的任何一個; 9876 + 543 = 10419

源碼:

struct ListNode* addTwoNumbers(struct ListNode* l1, struct ListNode* l2){struct ListNode* res = (struct ListNode*) calloc (1, sizeof(struct ListNode));struct ListNode* result = res; int a, b, c = 0; while(l1 != NULL || l2 != NULL || c != 0){ if(l1 != NULL){a = l1 -> val;l1 = l1 -> next;}else{a = 0;}if(l2 != NULL){b = l2 -> val;l2 = l2 -> next;}else{b = 0;}if(a + b + c >= 10){result->val = a+b+c-10;c = 1;}else{result->val = a+b+c;c = 0;}if(l1 != NULL || l2 != NULL || c != 0)result -> next = (struct ListNode*) calloc(1, sizeof(struct ListNode));result = result -> next;}return res; }

踩坑點:

題目本身算法不難,要注意的是采用鏈式存儲,就要考慮到:
1、開辟空間存儲結(jié)果,那么這個空間要開辟多大
2、如何避免空指針的問題(這個是真的ex到我了)
3、當一個鏈表已經(jīng)到了最后但另一個鏈表還有數(shù)據(jù)時,如何做到對應位相加。
    9,8,7,6和NULL,5,4,3;9和NULL如何相加

總結(jié)

以上是生活随笔為你收集整理的LeetCode:2. 两数相加(中等)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。