avatar
请教一个问题# JobHunting - 待字闺中
e*e
1
Given a BST in a language where memory must be handled manually, how do you
completely remove BST from memory? Recursion is not allowed. Was later told
that desired solution had O(N) time and O(1) space. ??????
实在是想不出不要 recursion O(1) 的办法
avatar
H*7
2
都得一个节点一个节点的删除吧?O1? 没有思路。等高人
avatar
l*l
3
Just a thought:
1. Restructure the binary tree (tree rotation) such that only root has two childern, other
nodes each has only one child. I think this can be done in
O(N).
2. Repeat root deleting. O(N).
avatar
j*u
4
如果把binary tree转成double linked list的话,时间是O(nlogn)肯定可以,时间O(n
)空间constant的还没想到。
假设树是满的,要么用logn的辅助空间暂存node,要么用logn的时间去找到没有或只有
一个child的node。是不是有什么tricky的办法?
avatar
l*l
5
Given:
1
2 3
4 5 6 7
avatar
j*u
6
NICE solution!

【在 l******l 的大作中提到】
: Given:
: 1
: 2 3
: 4 5 6 7

相关阅读
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。