国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

力扣---兩數(shù)相加(c語言版)

這篇具有很好參考價(jià)值的文章主要介紹了力扣---兩數(shù)相加(c語言版)。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問。

力扣---兩數(shù)相加(c語言版)

??個(gè)人主頁:?? :???初階牛???
??推薦專欄: ?????? c語言初階
??個(gè)人信條: ??知行合一
??本篇簡(jiǎn)介:>:記錄一個(gè)力扣寫了好久的一個(gè)問題
金句分享:
?在心里種花,人生才不會(huì)荒蕪!?

題目名稱:兩數(shù)相加(題目來源于力扣)

[傳送門]

前言:

此題被進(jìn)位問題困擾良久,所以注意看如何解決進(jìn)位問題.
另外,優(yōu)化版本的代碼將三種情況歸于一類值的思考.
希望對(duì)困擾此題的友友們有些幫助.

一、題目介紹:

給你兩個(gè) 非空 的鏈表,表示兩個(gè)非負(fù)的整數(shù)。它們每位數(shù)字都是按照 逆序 的方式存儲(chǔ)的,并且每個(gè)節(jié)點(diǎn)只能存儲(chǔ) 一位 數(shù)字。
請(qǐng)你將兩個(gè)數(shù)相加,并以相同形式返回一個(gè)表示和的鏈表。你可以假設(shè)除了數(shù)字 0 之外,這兩個(gè)數(shù)都不會(huì)以 0 開頭。

示例1:

力扣---兩數(shù)相加(c語言版)

輸入:l1 = [2,4,3], l2 = [5,6,4]
輸出:[7,0,8]
解釋:342 + 465 = 807.

示例2:

輸入:l1 = [0], l2 = [0]
輸出:[0]

示例3:

輸入:l1 = [9,9,9,9,9,9,9], l2 = [9,9,9,9]
輸出:[8,9,9,9,0,0,0,1]

二、解題思路分析:

1.創(chuàng)建一個(gè)帶頭結(jié)點(diǎn)的單鏈表(頭結(jié)點(diǎn)為sum),該鏈表用于存儲(chǔ)L1鏈表與L2鏈表的和.
2.創(chuàng)建spillnum用于保存進(jìn)位數(shù).
3.遍歷兩個(gè)鏈表,將結(jié)點(diǎn)中的值相加后存入sum鏈表:
此時(shí)分三種情況考慮:
①:兩個(gè)鏈表結(jié)點(diǎn)都不為空.
②:L1比較短,此時(shí)已經(jīng)走到NULL了.
③:L2比較短,此時(shí)已經(jīng)走到NULL了.
5.注意,還有一個(gè)重要情況,當(dāng)最后兩個(gè)數(shù)相加后也需要進(jìn)位時(shí),需要特殊處理.
6.返回頭結(jié)點(diǎn)的next結(jié)點(diǎn).

進(jìn)位數(shù)說明:

題目要求一個(gè)結(jié)點(diǎn)只能存?zhèn)€位數(shù),所以需要保留進(jìn)位數(shù)到下一個(gè)結(jié)點(diǎn).

算進(jìn)位數(shù):
這是很基本的數(shù)學(xué)問題,兩數(shù)相加,大于10的部分需要進(jìn)位.
力扣---兩數(shù)相加(c語言版)

2.1 代碼實(shí)現(xiàn)(low版本 ):

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
//創(chuàng)建一個(gè)新節(jié)點(diǎn)
struct ListNode* newNode(int x)
{
  
    struct ListNode* newnode = (struct ListNode*)malloc(sizeof(struct ListNode));
	if (newnode == NULL)
	{
		printf("申請(qǐng)新的節(jié)點(diǎn)失敗:\n");
		return NULL;
	}
	newnode->val = x;
	newnode->next = NULL;
	return newnode;
}
struct ListNode* addTwoNumbers(struct ListNode* l1, struct ListNode* l2){
    struct ListNode*sum=(struct ListNode*)malloc(sizeof(struct ListNode));
    struct ListNode*sumtail=sum;
    int spillnum=0;
    while(l1&&l2)//當(dāng)兩個(gè)鏈表都不為NULL時(shí)
    {
        struct ListNode*newnode=newNode((l1->val+l2->val+spillnum)%10);
        spillnum=(l1->val+l2->val+spillnum)/10;
        sumtail->next=newnode;
        sumtail=sumtail->next;
        l1=l1->next;
        l2=l2->next;
    }
    //一方已經(jīng)為NULL
    while(l1)
    {
        struct ListNode*newnode=newNode((l1->val+spillnum)%10);
        spillnum=(l1->val+spillnum)/10;
        sumtail->next=newnode;
        sumtail=sumtail->next;
        l1=l1->next;
    }
    while(l2)
    {
        struct ListNode*newnode=newNode((l2->val+spillnum)%10);
        spillnum=(l2->val+spillnum)/10;
        sumtail->next=newnode;
        sumtail=sumtail->next;
        l2=l2->next;
    }
    if(spillnum==0)
        return sum->next;
    else
        {
         	struct ListNode*newnode=newNode(spillnum);
         	sumtail->next=newnode;
        	 return sum->next;
        }
}

優(yōu)化點(diǎn):

①:將三種情況合并處理

如果兩個(gè)鏈表只要一方有數(shù)據(jù),則表示相加還需要繼續(xù).此時(shí)為避免空指針(NULL),將短的一方設(shè)置為0再與長(zhǎng)鏈表相加.
短的一方不再繼續(xù)后移(->next),用0代替.

②最后結(jié)點(diǎn)進(jìn)位代碼可以更加簡(jiǎn)潔一些.

2.2 代碼實(shí)現(xiàn)(優(yōu)化版本):

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
//創(chuàng)建一個(gè)新節(jié)點(diǎn)
struct ListNode* newNode(int x)
{
    struct ListNode* newnode = (struct ListNode*)malloc(sizeof(struct ListNode));
	newnode->val = x;
	newnode->next = NULL;
	return newnode;
}
struct ListNode* addTwoNumbers(struct ListNode* l1, struct ListNode* l2){
    struct ListNode*sum=(struct ListNode*)malloc(sizeof(struct ListNode));
    struct ListNode*sumtail=sum;//通過這個(gè)指針遍歷sum鏈表
    int spillnum=0;//進(jìn)位數(shù)
    while(l1||l2)//當(dāng)兩個(gè)鏈表其中一個(gè)還有元素的時(shí)候
    {   
       //如果一方為空,則將其值設(shè)置為0.
        int data1= l1==NULL ? 0 : l1->val;
        int data2= l2==NULL ? 0 : l2->val;

        int sum=(data1+data2+spillnum);//兩數(shù)之和+進(jìn)位數(shù)
        struct ListNode*newnode=newNode(sum%10);

        spillnum=sum/10;//處理進(jìn)位
        //為sum鏈表新增結(jié)點(diǎn)
        sumtail->next=newnode;
        sumtail=sumtail->next;

        if(l1)//如果L1不是NULL,則后移.
        l1=l1->next;
        if(l2)//如果L2不是NULL,則后移.
        l2=l2->next;
    }
    //最后一個(gè)結(jié)點(diǎn)也可能要進(jìn)位
    if(spillnum!=0)//如果進(jìn)位數(shù)不是0,說明最后一次相加需要進(jìn)位
    {
        struct ListNode*newnode=newNode(spillnum);
        sumtail->next=newnode;
    }
     return sum->next;
}

本題的解題經(jīng)驗(yàn)就分享到這里了,下次見!

力扣---兩數(shù)相加(c語言版)文章來源地址http://www.zghlxwxcb.cn/news/detail-409652.html

到了這里,關(guān)于力扣---兩數(shù)相加(c語言版)的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 2235.兩整數(shù)相加:19種語言解法(力扣全解法)

    2235.兩整數(shù)相加:19種語言解法(力扣全解法)

    力扣題目鏈接:https://leetcode.cn/problems/add-two-integers/ 給你兩個(gè)整數(shù)? num1 和 num2 ,返回這兩個(gè)整數(shù)的和。 ? 示例 1: 示例 2: ? 提示: -100 = num1, num2 = 100 時(shí)間復(fù)雜度 O ( 1 ) O(1) O ( 1 ) 空間復(fù)雜度 O ( 1 ) O(1) O ( 1 ) AC代碼 C++ C Python Python2 Java C# Javascript Ruby Swift Go Scala Kotlin Rust PHP

    2024年02月12日
    瀏覽(19)
  • LeetCode:2. 兩數(shù)相加

    LeetCode:2. 兩數(shù)相加

    給你兩個(gè)? 非空 ?的鏈表,表示兩個(gè)非負(fù)的整數(shù)。它們每位數(shù)字都是按照? 逆序 ?的方式存儲(chǔ)的,并且每個(gè)節(jié)點(diǎn)只能存儲(chǔ)? 一位 ?數(shù)字。 請(qǐng)你將兩個(gè)數(shù)相加,并以相同形式返回一個(gè)表示和的鏈表。 你可以假設(shè)除了數(shù)字 0 之外,這兩個(gè)數(shù)都不會(huì)以 0?開頭。 2. 兩數(shù)相加 - 力扣(

    2024年02月09日
    瀏覽(17)
  • 兩數(shù)相加

    給你兩個(gè) 非空 的鏈表,表示兩個(gè)非負(fù)的整數(shù)。它們每位數(shù)字都是按照 逆序 的方式存儲(chǔ)的,并且每個(gè)節(jié)點(diǎn)只能存儲(chǔ) 一位 數(shù)字。請(qǐng)你將兩個(gè)數(shù)相加,并以相同形式返回一個(gè)表示和的鏈表。你可以假設(shè)除了數(shù)字 0 之外,這兩個(gè)數(shù)都不會(huì)以 0 開頭。 輸入:l1 = [2,4,3], l2 = [5,6,4] 輸出

    2024年02月12日
    瀏覽(20)
  • 兩數(shù)相加問題

    兩數(shù)相加問題

    給你兩個(gè) 非空 的鏈表,表示兩個(gè)非負(fù)的整數(shù)。它們每位數(shù)字都是按照 逆序 的方式存儲(chǔ)的,并且每個(gè)節(jié)點(diǎn)只能存儲(chǔ) 一位 數(shù)字。 請(qǐng)你將兩個(gè)數(shù)相加,并以相同形式返回一個(gè)表示和的鏈表。 你可以假設(shè)除了數(shù)字 0 之外,這兩個(gè)數(shù)都不會(huì)以 0 開頭。 示例 1: 示例 2: 示例 3: 代

    2024年02月12日
    瀏覽(20)
  • 2. 兩數(shù)相加

    2. 兩數(shù)相加

    給你兩個(gè) 非空 的鏈表,表示兩個(gè)非負(fù)的整數(shù)。它們每位數(shù)字都是按照 逆序 的方式存儲(chǔ)的,并且每個(gè)節(jié)點(diǎn)只能存儲(chǔ) 一位 數(shù)字。 請(qǐng)你將兩個(gè)數(shù)相加,并以相同形式返回一個(gè)表示和的鏈表。 你可以假設(shè)除了數(shù)字 0 之外,這兩個(gè)數(shù)都不會(huì)以 0 開頭。 示例 1: 示例 2: 示例 3: 提

    2024年02月15日
    瀏覽(19)
  • LeetCode——兩數(shù)相加

    LeetCode——兩數(shù)相加

    目錄 一、兩數(shù)相加 1、題目 2、題目解讀 3、代碼 二、反轉(zhuǎn)鏈表 1、題目 ?2、題目解讀 3、代碼? 三、兩數(shù)相加 II 1、題目 2、題目解讀 3、代碼 反轉(zhuǎn)鏈表再進(jìn)行計(jì)算 借助棧 2. 兩數(shù)相加 - 力扣(Leetcode) 給你兩個(gè)? 非空 ?的鏈表,表示兩個(gè)非負(fù)的整數(shù)。它們每位數(shù)字都是按照

    2024年02月12日
    瀏覽(23)
  • 【刷題】 leetcode 2 .兩數(shù)相加

    【刷題】 leetcode 2 .兩數(shù)相加

    我們來看看題目,,,, 往往困難的題只需要 簡(jiǎn)單的敘述 。 好像只用找到兩個(gè)數(shù),整合成一個(gè)鏈表就可以。應(yīng)該 首先 我最快想到思路是 分別根據(jù)兩個(gè)鏈表求出對(duì)應(yīng)數(shù) 然后加一起 ,得到和 再把和拆分儲(chǔ)存到鏈表里 為此我們需要手撕一下鏈表頭插。 一頓操作猛如虎,一看

    2024年01月19日
    瀏覽(18)
  • 【每日一題】2. 兩數(shù)相加

    【每日一題】2. 兩數(shù)相加

    給你兩個(gè) 非空 的鏈表,表示兩個(gè)非負(fù)的整數(shù)。它們每位數(shù)字都是按照 逆序 的方式存儲(chǔ)的,并且每個(gè)節(jié)點(diǎn)只能存儲(chǔ) 一位 數(shù)字。 請(qǐng)你將兩個(gè)數(shù)相加,并以相同形式返回一個(gè)表示和的鏈表。 你可以假設(shè)除了數(shù)字 0 之外,這兩個(gè)數(shù)都不會(huì)以 0 開頭。 示例 1: 示例 2: 示例 3: 提

    2024年02月11日
    瀏覽(26)
  • 兩數(shù)相加 LeetCode熱題100

    給你兩個(gè) 非空 的鏈表,表示兩個(gè)非負(fù)的整數(shù)。它們每位數(shù)字都是按照 逆序 的方式存儲(chǔ)的,并且每個(gè)節(jié)點(diǎn)只能存儲(chǔ) 一位 數(shù)字。 請(qǐng)你將兩個(gè)數(shù)相加,并以相同形式返回一個(gè)表示和的鏈表。 你可以假設(shè)除了數(shù)字 0 之外,這兩個(gè)數(shù)都不會(huì)以 0 開頭。 建立鏈表l3,同時(shí)遍歷兩個(gè)鏈表

    2024年02月14日
    瀏覽(17)
  • leetcode 2. 兩數(shù)相加(java)

    leetcode 2. 兩數(shù)相加(java)

    難度 - 中等 leetcode 2. 兩數(shù)相加 給你兩個(gè) 非空 的鏈表,表示兩個(gè)非負(fù)的整數(shù)。它們每位數(shù)字都是按照 逆序 的方式存儲(chǔ)的,并且每個(gè)節(jié)點(diǎn)只能存儲(chǔ) 一位 數(shù)字。 請(qǐng)你將兩個(gè)數(shù)相加,并以相同形式返回一個(gè)表示和的鏈表。 你可以假設(shè)除了數(shù)字 0 之外,這兩個(gè)數(shù)都不會(huì)以 0 開頭。

    2024年02月09日
    瀏覽(22)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包