鏈表(五)——判斷鏈表入環(huán)點(diǎn)的應(yīng)用

LeetCode_287_FindtheDuplicateNumber

題目分析:

利用數(shù)組內(nèi)值都在下標(biāo)范圍內(nèi)的特點(diǎn)驰凛,數(shù)組可以有很多神奇操作稍浆,
第二種解法更是妙不可言刁赖。

解法一:

/**
 * 二分法:判斷在這區(qū)間內(nèi)的數(shù)的個(gè)數(shù)是否大于這份區(qū)間本身
 * 如果大于則一定有重復(fù)--- 鴿巢原理
 * [1, 4, 4, 2, 4]這種情況少3的情況也不必?fù)?dān)心 因?yàn)閰^(qū)間內(nèi)每少一個(gè)不重復(fù)數(shù) 必然多一個(gè)重復(fù)數(shù)
 */
public static int findDuplicate(int[] nums) {
    return find(1, nums.length - 1, nums);
}

public static int find(int begin, int end, int[] nums) {
    if(begin == end)
        return begin;

    int count = 0;
    int mid = (end + begin) / 2;
    for (int i = 0; i < nums.length; i++) {
        if(nums[i] >= begin && nums[i] <= mid)
            count++;
    }

    boolean inLeft = count > mid - begin + 1;

    if (inLeft) {
        return find(begin, mid, nums);
    } else
        return find(mid + 1, end, nums);
}

解法二:

/**
 * 若能證明:根據(jù)題意存在任意一組滿足要求的數(shù),可分為重復(fù)和非重復(fù)數(shù)兩類,
 * 一定存在一個(gè)按從nums[0]開始 善镰,step = nums[step]的步驟循環(huán)嵌套執(zhí)行形成的帶環(huán)鏈表跟衅,
 * 且入環(huán)口的值(某個(gè)nums[step]),一定是重復(fù)數(shù)的值石窑。
 * 則可按成環(huán)鏈表求入環(huán)口的方式操作牌芋,處理本題。
 *
 * 拆分為兩步的等效證明:
 * 證明1:從nums[0]開始,一定會(huì)走到nums[step]是重復(fù)數(shù)的一步
 * 證明2:nums[step]是重復(fù)數(shù)的情況松逊,那么nums[steps]之后成環(huán)躺屁,且是鏈表環(huán)入口
 *
 * 若能完成證明1,2 -- 即可完成證明棺棵。
 *
 * 引理1:若nums[step]是非重復(fù)數(shù)楼咳,一定會(huì)走到nums[step]是重復(fù)數(shù)
 *
 * 引理1證明:
 * 先假設(shè)我們能永遠(yuǎn)不走到nums[step]是重復(fù)數(shù),那執(zhí)行過程中必然在非重復(fù)數(shù)之間成環(huán)烛恤,只需證明費(fèi)非復(fù)數(shù)無法成環(huán)即可母怜。
 * 假設(shè)能成環(huán),入環(huán)口為某個(gè)非重復(fù)數(shù)缚柏,自然其位置是step_temp,值是nums[step_temp]苹熏,
 * 若要再次回到這個(gè)位置,必須是某另一個(gè)step等于step_temp,
 * (或者nums[step_temp] == step_temp,但這種情況最初就無法到達(dá)step_temp币喧,比如數(shù)值1在[1]位置上轨域,1不重復(fù),怎么都到不了)杀餐,
 * 由于不重復(fù)干发,所有永遠(yuǎn)無法回到該入環(huán)口,無法成環(huán)史翘。
 * 由于無法在非重復(fù)數(shù)位置間成環(huán)枉长,則必將走到非重復(fù)數(shù)以外的位置,而其他所有位置都是重復(fù)數(shù)琼讽,固一定會(huì)走到nums[step]是重復(fù)數(shù)必峰。
 * 證畢
 *
 * 證明1:
 * 由于一開始從nums[0]開始
 * 如果nums[0]本身是重復(fù)數(shù),則直接達(dá)成nums[step]是重復(fù)數(shù) -- 達(dá)成
 * 如果nums[0]本身是非重復(fù)數(shù)钻蹬,由引理1證明吼蚁,將走到nums[step]是重復(fù)數(shù) -- 達(dá)成
 * 證畢。
 *
 * 證明2:
 * 若nums[step]下一步也是重復(fù)數(shù)问欠,nums[steps]之后成環(huán)肝匆,且是鏈表環(huán)入口 -- 達(dá)成
 * 若nums[step]下一步是非重復(fù)數(shù)粒蜈,則由于引理論1,一定會(huì)走到nums[step]是重復(fù)數(shù)术唬,nums[steps]之后成環(huán)薪伏,且是鏈表環(huán)入口 -- 達(dá)成
 * 證畢
 *
 *
 */
public static int findDuplicate(int[] nums) {
    int slow = 0;
    int fast = 0;

    do {
        slow = nums[slow];
        fast = nums[nums[fast]];
    }while (slow != fast);

    slow = 0;
    while (slow != fast) {
        slow = nums[slow];
        fast = nums[fast];
    }

    return slow;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市粗仓,隨后出現(xiàn)的幾起案子嫁怀,更是在濱河造成了極大的恐慌,老刑警劉巖借浊,帶你破解...
    沈念sama閱讀 217,826評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件塘淑,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡蚂斤,警方通過查閱死者的電腦和手機(jī)存捺,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,968評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來曙蒸,“玉大人捌治,你說我怎么就攤上這事∨撸” “怎么了肖油?”我有些...
    開封第一講書人閱讀 164,234評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)臂港。 經(jīng)常有香客問我森枪,道長(zhǎng),這世上最難降的妖魔是什么审孽? 我笑而不...
    開封第一講書人閱讀 58,562評(píng)論 1 293
  • 正文 為了忘掉前任县袱,我火速辦了婚禮,結(jié)果婚禮上佑力,老公的妹妹穿的比我還像新娘式散。我一直安慰自己,他們只是感情好打颤,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,611評(píng)論 6 392
  • 文/花漫 我一把揭開白布杂数。 她就那樣靜靜地躺著,像睡著了一般瘸洛。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上次和,一...
    開封第一講書人閱讀 51,482評(píng)論 1 302
  • 那天反肋,我揣著相機(jī)與錄音,去河邊找鬼踏施。 笑死石蔗,一個(gè)胖子當(dāng)著我的面吹牛罕邀,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播养距,決...
    沈念sama閱讀 40,271評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼诉探,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了棍厌?” 一聲冷哼從身側(cè)響起肾胯,我...
    開封第一講書人閱讀 39,166評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎耘纱,沒想到半個(gè)月后敬肚,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,608評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡束析,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,814評(píng)論 3 336
  • 正文 我和宋清朗相戀三年艳馒,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片员寇。...
    茶點(diǎn)故事閱讀 39,926評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡弄慰,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蝶锋,到底是詐尸還是另有隱情陆爽,我是刑警寧澤,帶...
    沈念sama閱讀 35,644評(píng)論 5 346
  • 正文 年R本政府宣布牲览,位于F島的核電站墓陈,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏第献。R本人自食惡果不足惜贡必,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,249評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望庸毫。 院中可真熱鬧仔拟,春花似錦、人聲如沸飒赃。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,866評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽载佳。三九已至炒事,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蔫慧,已是汗流浹背挠乳。 一陣腳步聲響...
    開封第一講書人閱讀 32,991評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工诀豁, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留侄非,地道東北人搅方。 一個(gè)月前我還...
    沈念sama閱讀 48,063評(píng)論 3 370
  • 正文 我出身青樓悦屏,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親卖怜。 傳聞我的和親對(duì)象是個(gè)殘疾皇子屎开,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,871評(píng)論 2 354