亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語(yǔ)言刷題判斷鏈表中是否有環(huán)題解

 更新時(shí)間:2023年07月26日 10:42:38   作者:吳尼瑪  
這篇文章主要為大家介紹了C語(yǔ)言刷題判斷鏈表中是否有環(huán)題解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

題目

判斷給定的鏈表中是否有環(huán)。如果有環(huán)則返回true,否則返回false。

數(shù)據(jù)范圍:鏈表長(zhǎng)度 0≤n≤10000,鏈表中任意節(jié)點(diǎn)的值滿足 ∣val∣<=100000
要求:空間復(fù)雜度 O(1),時(shí)間復(fù)雜度 O(n)

輸入分為兩部分,第一部分為鏈表,第二部分代表是否有環(huán),然后將組成的head頭結(jié)點(diǎn)傳入到函數(shù)里面。-1代表無(wú)環(huán),其它的數(shù)字代表有環(huán),這些參數(shù)解釋僅僅是為了方便讀者自測(cè)調(diào)試。實(shí)際在編程時(shí)讀入的是鏈表的頭節(jié)點(diǎn)。

例如輸入{3,2,0,-4},1時(shí),對(duì)應(yīng)的鏈表結(jié)構(gòu)如下圖所示:

可以看出環(huán)的入口結(jié)點(diǎn)為從頭結(jié)點(diǎn)開(kāi)始的第1個(gè)結(jié)點(diǎn)(注:頭結(jié)點(diǎn)為第0個(gè)結(jié)點(diǎn)),所以輸出true。

示例1

輸入:
{3,2,0,-4},1
返回值:
true
說(shuō)明:
第一部分{3,2,0,-4}代表一個(gè)鏈表,第二部分的1表示,-4到位置1(注:頭結(jié)點(diǎn)為位置0),即-4->2存在一個(gè)鏈接,組成傳入的head為一個(gè)帶環(huán)的鏈表,返回true

示例2

輸入:
{1},-1
返回值:
false
說(shuō)明:
第一部分{1}代表一個(gè)鏈表,-1代表無(wú)環(huán),組成傳入head為一個(gè)無(wú)環(huán)的單鏈表,返回false

示例3

輸入:
{-1,-7,7,-4,19,6,-9,-5,-2,-5},6
返回值:
true

思路1

使用兩個(gè)指針,fast 與 slow。
它們起始都位于鏈表的頭部。隨后,slow 指針每次向后移動(dòng)一個(gè)位置,而fast 指針向后移動(dòng)兩個(gè)位置。如果鏈表中存在環(huán),則 fast 指針最終將再次與 slow 指針在環(huán)中相遇。

知識(shí)點(diǎn):雙指針

雙指針指的是在遍歷對(duì)象的過(guò)程中,不是普通的使用單個(gè)指針進(jìn)行訪問(wèn),而是使用兩個(gè)指針(特殊情況甚至可以多個(gè)),兩個(gè)指針或是同方向訪問(wèn)兩個(gè)鏈表、或是同方向訪問(wèn)一個(gè)鏈表(快慢指針)、或是相反方向掃描(對(duì)撞指針),從而達(dá)到我們需要的目的。

解答代碼1

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    bool hasCycle(ListNode *head) {
        if (head == nullptr) {
            return false;
        }
        // 定義快慢指針
        auto slow = head;
        auto fast = head;
        // 循環(huán)退出條件為快指針先到鏈表尾部
        while (fast != nullptr && fast->next != nullptr) {
            slow = slow->next;
            fast = fast->next->next;
            if (slow == fast) {
                // 快慢指針相遇表示有環(huán)
                return true;
            }
        }
        return false;
    }
};

思路2

遍歷鏈表中的每個(gè)節(jié)點(diǎn),并將它記錄下來(lái);一旦遇到了此前遍歷過(guò)的節(jié)點(diǎn),就可以判定鏈表中存在環(huán),需借助哈希表(C++中std::unordered_set)。

但這種解法的空間復(fù)雜度為O(N),其中 N 為鏈表中節(jié)點(diǎn)的數(shù)目。因?yàn)樾枰獙㈡湵碇械拿總€(gè)節(jié)點(diǎn)都保存在哈希表當(dāng)中。

解答代碼2

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
#include <unordered_set>
class Solution {
public:
    bool hasCycle(ListNode *head) {
        if (head == nullptr) {
            return false;
        }
        auto cur = head;
        std::unordered_set<ListNode *> sets;
        while (cur != nullptr) {
            if (sets.find(cur) != sets.end()) {
                // 在unordered_set中找到了,表示有環(huán)
                return true;
            } else
                sets.emplace(cur);
            cur = cur->next;
        }

以上就是C語(yǔ)言刷題判斷鏈表中是否有環(huán)題解的詳細(xì)內(nèi)容,更多關(guān)于C語(yǔ)言判斷鏈表是否有環(huán)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Qt利用QJson實(shí)現(xiàn)解析數(shù)組的示例詳解

    Qt利用QJson實(shí)現(xiàn)解析數(shù)組的示例詳解

    這篇文章主要為大家詳細(xì)介紹了Qt如何利用QJson實(shí)現(xiàn)解析數(shù)組功能,文中的示例代碼講解詳細(xì),對(duì)我們學(xué)習(xí)Qt有一定幫助,需要的小伙伴可以了解一下
    2022-10-10
  • C++動(dòng)態(tài)內(nèi)存管理詳解

    C++動(dòng)態(tài)內(nèi)存管理詳解

    今天小編就為大家分享一篇關(guān)于關(guān)于C++動(dòng)態(tài)分配內(nèi)存的介紹,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2021-08-08
  • 使用Matlab制作大富翁小游戲的過(guò)程詳解

    使用Matlab制作大富翁小游戲的過(guò)程詳解

    大富翁大家都玩過(guò),走到建筑的位置可以買(mǎi)地,第二圈走到買(mǎi)過(guò)的地可以升級(jí),別人經(jīng)過(guò)后需要付過(guò)路費(fèi),每次經(jīng)過(guò)起點(diǎn)都會(huì)獲得一定資金,玩到最后還沒(méi)破產(chǎn)的就是勝者,本文將制作一個(gè)Matlab版的大富翁小游戲,需要的可以參考一下
    2022-02-02
  • C語(yǔ)言指針類型與野指針引起的原因

    C語(yǔ)言指針類型與野指針引起的原因

    我們C語(yǔ)言獨(dú)一無(wú)二的特色——指針。說(shuō)起指針,可能很多人都是還沒(méi)學(xué)就已經(jīng)聽(tīng)說(shuō)過(guò)其鼎鼎大名,因?yàn)橛泻芏鄠餮院屯嫘κ裁吹恼f(shuō)指針很難,其實(shí)大家大可不必有畏難情緒,指針這個(gè)東西雖然確實(shí)有一定難度,但是這是基于其優(yōu)秀的靈活性而衍生的一點(diǎn)小問(wèn)題
    2023-02-02
  • 淺談使用Rapidxml 庫(kù)遇到的問(wèn)題和分析過(guò)程(分享)

    淺談使用Rapidxml 庫(kù)遇到的問(wèn)題和分析過(guò)程(分享)

    下面小編就為大家?guī)?lái)一篇淺談使用Rapidxml 庫(kù)遇到的問(wèn)題和分析過(guò)程(分享)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-05-05
  • C++內(nèi)存模型與名稱空間概念講解

    C++內(nèi)存模型與名稱空間概念講解

    這篇文章主要介紹了C++內(nèi)存模型與名稱空間,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧
    2023-01-01
  • C++實(shí)現(xiàn)動(dòng)態(tài)線性表

    C++實(shí)現(xiàn)動(dòng)態(tài)線性表

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)動(dòng)態(tài)線性表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • C++ 實(shí)戰(zhàn)開(kāi)發(fā)一個(gè)猜單詞的小游戲

    C++ 實(shí)戰(zhàn)開(kāi)發(fā)一個(gè)猜單詞的小游戲

    眾所周知紙上得來(lái)終覺(jué)淺,我們要在實(shí)戰(zhàn)中才能真正的掌握技術(shù),小編為大家?guī)?lái)一份用C++編寫(xiě)的猜單詞小游戲,給大家練練手,快來(lái)看看吧
    2021-11-11
  • QT實(shí)現(xiàn)貪吃蛇游戲代碼詳解

    QT實(shí)現(xiàn)貪吃蛇游戲代碼詳解

    本文主要為大家詳細(xì)介紹了在QT中實(shí)現(xiàn)貪吃蛇游戲的詳細(xì)教程,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • C語(yǔ)言實(shí)現(xiàn)的一個(gè)萬(wàn)年歷小程序

    C語(yǔ)言實(shí)現(xiàn)的一個(gè)萬(wàn)年歷小程序

    這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)的一個(gè)萬(wàn)年歷小程序,具有一定的參考價(jià)值,做C語(yǔ)言日期計(jì)算的朋友可以參考下
    2014-07-07

最新評(píng)論