關(guān)于javascript的一道面試題
問題描述
忘記當(dāng)時(shí)問的啥了,因?yàn)榱牡谋容^多,記性不好.大概是'如何判斷鏈?zhǔn)欠裼协h(huán)'只依稀記得這個(gè)意思...謝謝各位幫我把問題糾正下.我主要想知道問的是什么.
問題解答
回答1:這個(gè)問的有點(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)鏈表。
那么到底要如何判斷呢?既然他說要我判斷,按照上面的做法。
遞歸
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
(寫完發(fā)現(xiàn)寫錯(cuò)又重寫... = = 抱歉了)
回答2:這道題目是一個(gè)非常經(jīng)典的算法題,最經(jīng)典的做法是使用 快慢指針法 ,具體題目可以移步 leetcode
簡(jiǎn)單來說,定義快指針和慢指針,快的一次走兩步,慢的一次走一步,如果他們兩個(gè)能相遇,則說明有環(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;};
相關(guān)文章:
1. android - 哪位大神知道java后臺(tái)的api接口的對(duì)象傳到前端后輸入日期報(bào)錯(cuò),是什么情況?求大神指點(diǎn)2. PHPExcel表格導(dǎo)入數(shù)據(jù)庫怎么導(dǎo)入3. android - weex 項(xiàng)目createInstanceReferenceError: Vue is not defined4. pdo 寫入到數(shù)據(jù)庫的內(nèi)容為中文的時(shí)候?qū)懭雭y碼5. javascript - 如圖,百度首頁,查看源代碼為什么什么都沒有?6. vue2.0+webpack 如何使用bootstrap?7. PHP類封裝的插入數(shù)據(jù),總是插入不成功,返回false;8. mac連接阿里云docker集群,已經(jīng)卡了2天了,求問?9. android - 分享到微信,如何快速轉(zhuǎn)換成字節(jié)數(shù)組10. javascript - 關(guān)于正則表達(dá)式的一些問題
