久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

關(guān)于javascript的一道面試題

瀏覽:134日期:2023-03-09 08:30:54

問(wèn)題描述

忘記當(dāng)時(shí)問(wèn)的啥了,因?yàn)榱牡谋容^多,記性不好.大概是'如何判斷鏈?zhǔn)欠裼协h(huán)'只依稀記得這個(gè)意思...謝謝各位幫我把問(wèn)題糾正下.我主要想知道問(wèn)的是什么.

問(wèn)題解答

回答1:

這個(gè)問(wèn)的有點(diǎn)厲害

var a = { val: ’a’}, b = { val: ’b’}, c = { val: ’c’}; a.next = b;b.next = c; c.next = a;

a.next 是 bb.next 是 cc.next 是 a..... .....

如果執(zhí)行以下循環(huán)

var temp = a; while(tamp){ temp = temp.next; }

那么將會(huì)是個(gè)死循環(huán),temp會(huì)被如下賦值: a => b => c => a => b ..... 這樣的 abc 就是構(gòu)成了一個(gè)環(huán)

你可以參考一下循環(huán)隊(duì)列,環(huán)鏈表。

那么到底要如何判斷呢?

既然他說(shuō)要我判斷,按照上面的做法。

遞歸

function isCircle(list, head){ // 默認(rèn)值 head = head || list; if (list.next === head){ // 相等 console.log(’是循環(huán)的’); return true; } else if (!list.next) { // 下一個(gè)? 不存在的 console.log(’不是循環(huán)的’);return false; } else {// 繼續(xù)遞歸 return isCircle(list.next, head); }}ScreenShot

關(guān)于javascript的一道面試題

(寫(xiě)完發(fā)現(xiàn)寫(xiě)錯(cuò)又重寫(xiě)... = = 抱歉了)

回答2:

這道題目是一個(gè)非常經(jīng)典的算法題,最經(jīng)典的做法是使用 快慢指針?lè)?,具體題目可以移步 leetcode

簡(jiǎn)單來(lái)說(shuō),定義快指針和慢指針,快的一次走兩步,慢的一次走一步,如果他們兩個(gè)能相遇,則說(shuō)明有環(huán)。

var hasCycle = function(head) { if(!head) return false; var faster = head; var slower = head; while (faster && faster.next) {faster = faster.next.next;slower = slower.next;if (slower === faster) return true; } return false;};

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 石狮市| 陆河县| 梁平县| 西峡县| 林芝县| 道真| 翼城县| 苏尼特右旗| 丹棱县| 栖霞市| 江达县| 庆阳市| 汉源县| 托克托县| 清涧县| 乐清市| 旺苍县| 伊金霍洛旗| 兴文县| 盐山县| 峡江县| 嘉鱼县| 静宁县| 红桥区| 德兴市| 永州市| 平陆县| 昌图县| 龙井市| 都昌县| 莱西市| 达拉特旗| 麻阳| 武冈市| 五常市| 长宁县| 棋牌| 三亚市| 葫芦岛市| 大足县| 宁安市|