关于javascript的一道面试题
问题描述
忘记当时问的啥了,因为聊的比较多,记性不好.大概是'如何判断链是否有环'只依稀记得这个意思...谢谢各位帮我把问题纠正下.我主要想知道问的是什么.
问题解答
回答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

(写完发现写错又重写... = = 抱歉了)
回答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;};
相关文章:
1. docker内创建jenkins访问另一个容器下的服务器问题2. objective-c - 微信支付的问题3. javascript - QQ第三方登录的问题4. java - web端百度网盘的一个操作为什么要分两次请求服务器, 有什么好处吗5. java - 如何点击按钮,重新运行(我是初学者)?6. java - Spring boot 读取 放在 jar 包外的,log4j 配置文件,系统有创建日志文件,不写入日志信息。7. angular.js使用$resource服务把数据存入mongodb的问题。8. python - 《flask web 开发》一书,数据库中多对多关系的实现问题?9. javascript - 使用百度文本编辑器ueditor不显示样式问题10. android - 使用百度sdk调用SDKInitializer.initialize(this)时报错?

网公网安备