国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

關于javascript的一道面試題

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

問題描述

忘記當時問的啥了,因為聊的比較多,記性不好.大概是'如何判斷鏈是否有環'只依稀記得這個意思...謝謝各位幫我把問題糾正下.我主要想知道問的是什么.

問題解答

回答1:

這個問的有點厲害

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..... .....

如果執行以下循環

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

那么將會是個死循環,temp會被如下賦值: a => b => c => a => b ..... 這樣的 abc 就是構成了一個環

你可以參考一下循環隊列,環鏈表。

那么到底要如何判斷呢?

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

遞歸

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

關于javascript的一道面試題

(寫完發現寫錯又重寫... = = 抱歉了)

回答2:

這道題目是一個非常經典的算法題,最經典的做法是使用 快慢指針法 ,具體題目可以移步 leetcode

簡單來說,定義快指針和慢指針,快的一次走兩步,慢的一次走一步,如果他們兩個能相遇,則說明有環。

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;};

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 一级黄色录像片 | 99久久精品免费观看区一 | 波多野结衣在线观看高清免费资源 | 日韩一级片网址 | 精品久久久久久影院免费 | 日韩一级a毛片欧美区 | 欧美一级视频在线观看 | 免费毛片播放 | 97欧美精品一区二区三区 | 一本久道久久综合婷婷五 | 国产一区二区在线 |播放 | 美女毛片在线观看 | 欧美三级做爰视频 | 亚州免费一级毛片 | 久久久久久久综合 | 中文字幕最新中文字幕中文字幕 | 美女网站在线观看视频18 | 99热精品在线免费观看 | 日韩成人午夜 | 欧美日韩亚洲一区二区三区 | 亚洲第一中文字幕 | 亚洲欧美日韩国产专区一区 | 亚洲精品一区二区三区在线观看 | 狠狠色狠狠色综合日日32 | www.日本高清视频.com | 毛片免费观看的视频 | 大尺度福利视频奶水在线 | 国产99高清一区二区 | 久久久精品免费观看 | 中文字幕一区二区三区视频在线 | 国产日韩欧美一区二区三区在线 | 久久精品久久久 | 国产成a人片在线观看视频 国产成版人视频网站免费下 | 手机免费在线看毛片 | 久草com| 亚洲一区欧美二区 | 亚欧精品一区二区三区 | 亚洲人成高清毛片 | 国产91精品高清一区二区三区 | 中文字幕精品一区二区绿巨人 | 精品国产成人系列 |