欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++相交鏈表和反轉(zhuǎn)鏈表詳解

 更新時間:2021年08月19日 10:27:06   作者:久病成良醫(yī)  
這篇文章主要介紹了C++相交鏈表和反轉(zhuǎn)鏈表,結(jié)合實例形式分析了C++相交鏈表和反轉(zhuǎn)鏈表的原理、實現(xiàn)方法及相關(guān)注意事項,需要的朋友可以參考下

給你兩個單鏈表的頭節(jié)點 headA 和 headB ,請你找出并返回兩個單鏈表相交的起始節(jié)點。如果兩個鏈表沒有交點,返回 null 。

在這里插入圖片描述

思路

簡單來說,就是求兩個鏈表交點節(jié)點的 指針。 這里同學(xué)們要注意,交點不是數(shù)值相等,而是指針相等。

為了方便舉例,假設(shè)節(jié)點元素數(shù)值相等,則節(jié)點指針相等。

看如下兩個鏈表,目前curA指向鏈表A的頭結(jié)點,curB指向鏈表B的頭結(jié)點:

在這里插入圖片描述

我們求出兩個鏈表的長度,并求出兩個鏈表長度的差值,然后讓curA移動到,和curB 末尾對齊的位置,如圖:

在這里插入圖片描述

此時我們就可以比較curA和curB是否相同,如果不相同,同時向后移動curA和curB,如果遇到curA == curB,則找到焦點。

否則循環(huán)退出返回空指針。

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode *getIntersectionNode(ListNode *headA, ListNode *headB) {
        ListNode* curA=headA;
        ListNode* curB=headB;
        int lenA=0;
        int lenB=0;
        while(curA!=nullptr){  // 求鏈表A的長度
            lenA++;
            curA=curA->next;
        }
        while(curB!=nullptr){  // 求鏈表B的長度
            lenB++;
            curB=curB->next;
        }
        //現(xiàn)在的curA,curB已經(jīng)指向最后一個節(jié)點了,需要重新指向頭結(jié)點
        curA=headA;
        curB=headB; 
        if(lenA<lenB){  //假設(shè)鏈表A的長度大于鏈表B,否則交換
            swap(lenA,lenB);
            swap(curA,curB);
        }
        //gap是兩個鏈表長度的差值
        int gap=lenA-lenB; // gap=lenA-lenB 錯誤,要有返回類型
        while(gap){     // 讓curA和curB在同一起點上(末尾位置對齊)
            gap--;
            curA=curA->next;  
        }
        while(lenB){   // 遍歷curA 和 curB,遇到相同則直接返回
            if(curA==curB)
                return curA; // return curA(val) 返回節(jié)點中的值,這個寫法是錯誤的  直接return curA
            curA=curA->next;
            curB=curB->next;
            lenB--;
        } 
        return nullptr;  //沒有交點則返回空
    }
};

給你單鏈表的頭節(jié)點 head ,請你反轉(zhuǎn)鏈表,并返回反轉(zhuǎn)后的鏈表。

示例 1:

輸入:head = [1,2,3,4,5]

輸出:[5,4,3,2,1]

示例 2:

輸入:head = [1,2]

輸出:[2,1]

示例 3:

輸入:head = []

輸出:[]

雙指針思路

首先判斷鏈表是否為空,為空則返回nullptr。

接下來定義一個cur指針,指向頭結(jié)點,再定義一個pre指針,初始化為null。

然后就要開始反轉(zhuǎn)了,首先要把 cur->next 節(jié)點用tmp指針保存一下,也就是保存一下這個節(jié)點。

為什么要保存一下這個節(jié)點呢,因為接下來要改變 cur->next 的指向了,將cur->next 指向pre ,此時已經(jīng)反轉(zhuǎn)了第一個節(jié)點了。

接下來,就是循環(huán)走如下代碼邏輯了,繼續(xù)移動pre和cur指針。

最后,cur 指針已經(jīng)指向了null,循環(huán)結(jié)束,鏈表也反轉(zhuǎn)完畢了。 此時我們return pre指針就可以了,pre指針就指向了新的頭結(jié)點。

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* reverseList(ListNode* head) {
        if(head==nullptr)  //對空鏈表的判斷
            return nullptr;
        ListNode* per=nullptr;
        ListNode* cur=head;
        ListNode* temp; //建立一個指針
        while(cur){  //沒必要寫 while(cur!=nullptr),寫了這個還要判斷cur,會浪費時間,直接cur就可以
            temp=cur->next; //保存cur的下一個節(jié)點
            cur->next=per; //cur的下一個節(jié)點指向per,實現(xiàn)反轉(zhuǎn)
            per=cur;  //cur=per;錯誤,是把cur的節(jié)點賦值給per
            cur=temp; //temp=cur;錯誤,是把temp(原來的cur->next)的節(jié)點賦值給cur
        }
        return per;
    }
};

遞歸

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* reverse(ListNode* per,ListNode* cur){  //返回的是一個鏈表,其返回值是指針
        if(cur==nullptr)  //遞歸的終止條件
            return per;
        ListNode* temp=cur->next;
        cur->next=per;
        return reverse(cur,temp); // 調(diào)用要寫return
    }
    ListNode* reverseList(ListNode* head) {
        if(head==nullptr) //鏈表判空
            return nullptr; 
        return reverse(NULL,head); // 調(diào)用要寫return
    }
};

總結(jié)

本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!

相關(guān)文章

  • C語言新手入門之格式化輸出和變量類型

    C語言新手入門之格式化輸出和變量類型

    這篇文章主要給大家介紹了關(guān)于C語言中格式化輸出和變量類型的相關(guān)資料,文中的教程非常適合新手零基礎(chǔ)的朋友們參考學(xué)習(xí),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-03-03
  • OpenCV透視變換應(yīng)用之書本視圖矯正+廣告屏幕切換

    OpenCV透視變換應(yīng)用之書本視圖矯正+廣告屏幕切換

    透視變換是指利用透視中心、像點、目標點三點共線的條件,按透視旋轉(zhuǎn)定律使承影面繞跡線旋轉(zhuǎn)某一角度,破壞原有的投影光線束,仍能保持承影面上投影幾何圖形不變的變換。本文將為大家介紹兩個OpenCV透視變換應(yīng)用,需要的可以參考一下
    2022-08-08
  • 淺談C++流庫的基本結(jié)構(gòu)

    淺談C++流庫的基本結(jié)構(gòu)

    本文主要介紹了淺談C++流庫的基本結(jié)構(gòu),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-04-04
  • C語言歸排與計排深度理解

    C語言歸排與計排深度理解

    這篇文章主要為大家詳細的介紹了C語言中計數(shù)排序和歸并排序,歸并排序是創(chuàng)建在歸并操作上的一種有效的排序算法,計數(shù)排序不用比較兩個數(shù)的大小,感興趣的朋友可以參考閱讀
    2023-04-04
  • 利用C++實現(xiàn)矩陣的相加/相稱/轉(zhuǎn)置/求鞍點

    利用C++實現(xiàn)矩陣的相加/相稱/轉(zhuǎn)置/求鞍點

    利用C++實現(xiàn)矩陣的相加/相稱/轉(zhuǎn)置/求鞍點。需要的朋友可以過來參考下,希望對大家有所幫助
    2013-10-10
  • C++中constexpr與模板元編程的基礎(chǔ)、常見問題、易錯點及其規(guī)避策略

    C++中constexpr與模板元編程的基礎(chǔ)、常見問題、易錯點及其規(guī)避策略

    C++編譯時計算允許程序在編譯階段完成計算任務(wù),constexpr與模板元編程是C編譯時計算的兩把利劍,它們不僅能夠提升程序的性能,還能增強代碼的健壯性和可維護性,通過避開本文闡述的易錯點,開發(fā)者可以更加得心應(yīng)手地運用這些特性,編寫出既高效又優(yōu)雅的C代碼
    2024-06-06
  • C語言程序設(shè)計50例(經(jīng)典收藏)

    C語言程序設(shè)計50例(經(jīng)典收藏)

    本篇文章是對C語言程序設(shè)計的50個小案例進行了詳細的分析介紹,需要的朋友參考下
    2013-06-06
  • C語言中字符串庫函數(shù)的實現(xiàn)及模擬

    C語言中字符串庫函數(shù)的實現(xiàn)及模擬

    C語言中有很多數(shù)據(jù)類型,比如int(整數(shù)類型)、char(字符類型)、以及浮點型的double(雙精度)等。但是有一點就是我們發(fā)現(xiàn)這里并沒有提到我們常見的有關(guān)字符串的類型。本文為大家介紹了C語言中字符串庫函數(shù)的實現(xiàn)及模擬,需要的可以參考一下
    2022-11-11
  • C++實現(xiàn)LeetCode(171.求Excel表列序號)

    C++實現(xiàn)LeetCode(171.求Excel表列序號)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(171.求Excel表列序號),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • C++ assert()函數(shù)用法案例詳解

    C++ assert()函數(shù)用法案例詳解

    這篇文章主要介紹了C++ assert()函數(shù)用法案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-09-09

最新評論