- 33
- 0
写了一个二叉树,然后分别使用广度遍历和深度遍历,为什么广度遍历比深度遍历用的时间长很多呢?
遍历的次数是相同的。
初学算法,请各位指教
class Node {
constructor (data, left, right) {
this.data = data
this.left = left
this.right = right
}
}
class BST {
constructor() {
this.root = null
this.ordered = []
this.times = 0
}
insert (data) {
var node = new Node(data, null, null)
if (this.root === null) {
this.root = node
} else {
var current = this.root
var parent
while(current !== null) {
parent = current
if (data < current.data) {
current = current.left
} else if (data > current.data){
current = current.right
} else {
return
}
}
data < parent.data ? (parent.left = node) : (parent.right = node)
}
}
inOrder(node) {
if (node !== null) {
this.times++
this.inOrder(node.left)
this.ordered.push(node.data)
this.inOrder(node.right)
}
}
// 广度优先遍历
bfs() {
var arr = []
arr.push(this.root)
while(arr.length) {
this.times++
var node = arr.shift()
this.ordered.push(node.data)
if (node.left) {
arr.push(node.left)
}
if (node.right) {
arr.push(node.right)
}
}
}
}
// test
var nums = new BST();
for (var j = 0; j < 100000; j++) {
nums.insert(Math.floor(Math.random()*100000))
}
console.time('bfs')
nums.bfs()
console.timeEnd('bfs')
console.log(nums.times)
nums.ordered.length = 0
nums.times = 0
console.time('inorder')
nums.inOrder(nums.root);
console.timeEnd('inorder')
console.log(nums.times) 2
打赏
收藏
点击回答
您的回答被采纳后将获得:提问者悬赏的 11 元积分
网站公告
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部
