青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

面對(duì)現(xiàn)實(shí),超越自己
逆水行舟,不進(jìn)則退
posts - 269,comments - 32,trackbacks - 0
轉(zhuǎn)自:http://m.shnenglu.com/humanchao/archive/2008/04/17/47357.html


有一個(gè)單鏈表,其中可能有一個(gè)環(huán),也就是某個(gè)節(jié)點(diǎn)的next指向的是鏈表中在它之前的節(jié)點(diǎn),這樣在鏈表的尾部形成一環(huán)。

問(wèn)題:

1、如何判斷一個(gè)鏈表是不是這類(lèi)鏈表?
2、如果鏈表為存在環(huán),如何找到環(huán)的入口點(diǎn)?

解答:

一、判斷鏈表是否存在環(huán),辦法為:

設(shè)置兩個(gè)指針(fast, slow),初始值都指向頭,slow每次前進(jìn)一步,fast每次前進(jìn)二步,如果鏈表存在環(huán),則fast必定先進(jìn)入環(huán),而slow后進(jìn)入環(huán),兩個(gè)指針必定相遇。(當(dāng)然,fast先行頭到尾部為NULL,則為無(wú)環(huán)鏈表)程序如下:

bool IsExitsLoop(slist *head)
{
    slist
*slow = head*fast = head;

    while ( fast && fast->next ) 
    {
        slow 
= slow->next;
        fast 
= fast->next->next;
       
if ( slow == fast ) break;
    }

    return !(fast == NULL || fast->next == NULL);
}

二、找到環(huán)的入口點(diǎn)

當(dāng)fast若與slow相遇時(shí),slow肯定沒(méi)有走遍歷完鏈表,而fast已經(jīng)在環(huán)內(nèi)循環(huán)了n圈(1<=n)。假設(shè)slow走了s步,則fast走了2s步(fast步數(shù)還等于s 加上在環(huán)上多轉(zhuǎn)的n圈),設(shè)環(huán)長(zhǎng)為r,則:

2s = s + nr
s= nr

設(shè)整個(gè)鏈表長(zhǎng)L,入口環(huán)與相遇點(diǎn)距離為x,起點(diǎn)到環(huán)入口點(diǎn)的距離為a。
a + x = nr
a + x = (n – 1)r +r = (n-1)r + L - a
a = (n-1)r + (L – a – x)

(L – a – x)為相遇點(diǎn)到環(huán)入口點(diǎn)的距離,由此可知,從鏈表頭到環(huán)入口點(diǎn)等于(n-1)循環(huán)內(nèi)環(huán)+相遇點(diǎn)到環(huán)入口點(diǎn),于是我們從鏈表頭、與相遇點(diǎn)分別設(shè)一個(gè)指針,每次各走一步,兩個(gè)指針必定相遇,且相遇第一點(diǎn)為環(huán)入口點(diǎn)。程序描述如下:

slist* FindLoopPort(slist *head)
{
    slist
*slow = head, *fast = head;

    while ( fast && fast->next ) 
    {
        slow 
= slow->next;
        fast 
= fast->next->next;
       
if ( slow == fast ) break;
    }

    if (fast == NULL || fast->next == NULL)
   
    return NULL;

    slow 
= head;
    while (slow != fast)
    {
         slow 
= slow->next;
         fast 
= fast->next;
    }

    return slow;
}


擴(kuò)展問(wèn)題:

判斷兩個(gè)單鏈表是否相交,如果相交,給出相交的第一個(gè)點(diǎn)(兩個(gè)鏈表都不存在環(huán))。

比較好的方法有兩個(gè):

一、將其中一個(gè)鏈表首尾相連,檢測(cè)另外一個(gè)鏈表是否存在環(huán),如果存在,則兩個(gè)鏈表相交,而檢測(cè)出來(lái)的依賴(lài)環(huán)入口即為相交的第一個(gè)點(diǎn)。

二、如果兩個(gè)鏈表相交,那個(gè)兩個(gè)鏈表從相交點(diǎn)到鏈表結(jié)束都是相同的節(jié)點(diǎn),我們可以先遍歷一個(gè)鏈表,直到尾部,再遍歷另外一個(gè)鏈表,如果也可以走到同樣的結(jié)尾點(diǎn),則兩個(gè)鏈表相交。

這時(shí)我們記下兩個(gè)鏈表length,再遍歷一次,長(zhǎng)鏈表節(jié)點(diǎn)先出發(fā)前進(jìn)(lengthMax-lengthMin)步,之后兩個(gè)鏈表同時(shí)前進(jìn),每次一步,相遇的第一點(diǎn)即為兩個(gè)鏈表相交的第一個(gè)點(diǎn)。

posted on 2012-04-09 16:56 王海光 閱讀(770) 評(píng)論(0)  編輯 收藏 引用 所屬分類(lèi): 算法
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            99国产精品久久久久老师 | 久久久视频精品| 亚洲免费精品| 亚洲人成亚洲人成在线观看图片| 老司机成人网| 欧美.日韩.国产.一区.二区| 欧美高清视频| 日韩亚洲欧美一区二区三区| 99热在这里有精品免费| 亚洲在线日韩| 久久狠狠亚洲综合| 狂野欧美一区| 欧美日韩国产探花| 国产日韩一区二区三区在线播放 | 亚洲国产99精品国自产| 亚洲国产小视频| 一区二区三区四区五区视频| 午夜精品在线| 欧美国产日韩视频| 午夜精品久久久久影视| 蜜桃av综合| 国产精品久久福利| 91久久综合亚洲鲁鲁五月天| 性欧美暴力猛交另类hd| 欧美激情综合| 欧美在线国产精品| 国产精品麻豆va在线播放| 亚洲国产一区在线| 久久精品国产2020观看福利| 亚洲日本成人| 久久精品亚洲一区| 欧美视频免费看| 在线成人小视频| 亚洲欧美日韩区| 亚洲人成人一区二区在线观看 | 亚洲精品国产精品国自产观看浪潮| 一本色道久久综合亚洲精品高清| 久久免费99精品久久久久久| 一本色道久久综合亚洲精品高清 | 国产一区999| a4yy欧美一区二区三区| 久久久综合网| 亚洲欧美韩国| 国产精品国产自产拍高清av| 亚洲激情女人| 久久人人爽人人| 亚洲一区二三| 午夜精品久久| 欧美一二三区精品| 最新热久久免费视频| 久久精品视频在线看| 国产美女精品视频| 性欧美暴力猛交69hd| 亚洲午夜电影| 欧美日韩国产影院| 亚洲激情成人| 欧美国产日韩一区二区在线观看| 欧美中日韩免费视频| 国产美女一区二区| 亚洲自拍偷拍视频| 一本到高清视频免费精品| 欧美日韩高清在线| 亚洲在线播放电影| 一区二区免费看| 欧美人妖在线观看| 亚洲少妇自拍| 亚洲一级二级在线| 国产一级揄自揄精品视频| 久久婷婷影院| 久久野战av| 日韩视频二区| 一区二区三区成人精品| 国产精品视频一二| 久久精品毛片| 久久久综合网站| 亚洲黄色在线视频| 99riav1国产精品视频| 国产精品嫩草久久久久| 久久精品中文字幕一区| 久久在线免费观看视频| 亚洲精品视频免费观看| 日韩写真视频在线观看| 国产精品嫩草影院av蜜臀| 久久免费精品日本久久中文字幕| 老巨人导航500精品| 亚洲在线视频一区| 麻豆91精品91久久久的内涵| 99精品视频免费| 亚洲欧美日韩国产中文| 尤妮丝一区二区裸体视频| 亚洲日本中文| 国产视频久久| 亚洲欧洲在线看| 国产亚洲欧洲997久久综合| 亚洲国产高清在线| 国产在线精品二区| 亚洲精选大片| 精品96久久久久久中文字幕无| 亚洲国产另类久久精品| 国产精品亚洲综合天堂夜夜| 欧美jjzz| 国产精品视频1区| 亚洲国产乱码最新视频| 国产精品一区二区女厕厕| 欧美激情aaaa| 国产香蕉97碰碰久久人人| 亚洲日本在线观看| 伊人狠狠色j香婷婷综合| 一本色道久久综合亚洲精品按摩| 亚洲国产精品123| 亚洲欧洲三级电影| 欧美在线三级| 亚洲永久免费av| 牛人盗摄一区二区三区视频| 午夜精品一区二区三区在线视| 欧美xx69| 欧美顶级大胆免费视频| 国产亚洲日本欧美韩国| 亚洲一级电影| 亚洲综合成人婷婷小说| 欧美极品欧美精品欧美视频| 蜜桃伊人久久| 好看不卡的中文字幕| 亚洲性xxxx| 亚洲一区免费看| 欧美激情一区二区| 亚洲国产精品久久久久秋霞不卡| 国产日韩欧美中文| 久久福利资源站| 久久久精品欧美丰满| 国产欧美91| 亚洲欧美精品中文字幕在线| 亚洲永久视频| 国产精品久久7| 亚洲一区二区在线看| 亚洲欧美韩国| 国产精品九九久久久久久久| 一区二区三区欧美成人| 欧美一区影院| 欧美一区二区三区在线看| 欧美三级电影一区| 日韩亚洲一区二区| 亚洲香蕉成视频在线观看| 欧美国产激情二区三区| 亚洲国产精品va在线观看黑人| 在线观看一区| 久久字幕精品一区| 欧美成人中文字幕在线| 亚洲国产影院| 欧美精品一区在线| 99国产精品久久久久久久久久| 艳妇臀荡乳欲伦亚洲一区| 欧美激情一区二区三区全黄| 91久久综合亚洲鲁鲁五月天| 亚洲精品综合| 欧美日韩国语| 亚洲一线二线三线久久久| 久久久噜噜噜久久人人看| 亚洲电影在线看| 欧美激情亚洲自拍| 午夜欧美精品| 免费中文日韩| 一区二区三区四区在线| 国产欧美一区视频| 久久亚洲国产成人| 99xxxx成人网| 老色批av在线精品| 亚洲在线电影| 国内精品久久久久久影视8| 久久一区二区三区国产精品 | 欧美诱惑福利视频| 久久综合福利| 亚洲精品视频中文字幕| 欧美日本亚洲韩国国产| 欧美一级在线亚洲天堂| 欧美激情一区二区三区高清视频| 亚洲一区二区三区国产| 国产精品日韩久久久久| 一本久久综合亚洲鲁鲁五月天| 亚洲欧美不卡| 一区二区三区在线观看欧美| 欧美黄色免费| 亚洲综合色在线| 欧美大片国产精品| 午夜精品福利一区二区三区av| 韩国精品在线观看| 欧美日韩中文字幕| 久久夜色精品一区| 亚洲在线观看免费视频| 亚洲国产欧美一区| 久久激情视频久久| 一区二区三区 在线观看视频| 国产综合18久久久久久| 国产精品黄视频| 欧美国产专区| 久久精品视频播放| 亚洲自拍偷拍视频| 99在线精品视频在线观看| 欧美激情一区二区三区四区| 久久理论片午夜琪琪电影网|