题解 | #二叉搜索树与双向链表#

二叉搜索树与双向链表

http://www.nowcoder.com/practice/947f6eb80d944a84850b0538bf0ec3a5

/*
struct TreeNode {
int val;
struct TreeNode left;
struct TreeNode *right;
TreeNode(int x) :
val(x), left(NULL), right(NULL) {
}
};
/
class Solution {
public:
map<int, TreeNode> m;
vector<int> v;
void bianli(TreeNode</int>
root){
if(!root) return;
bianli(root->left);
m[root->val] = root;
v.push_back(root->val);
bianli(root->right);
return;
}
TreeNode* Convert(TreeNode* pRootOfTree) {
if(!pRootOfTree) return {};
bianli(pRootOfTree);
m[v[0]]->right = m[v[1]];
m[v[v.size()-1]]->left = m[v[v.size()-2]];
for(int i=1;i<v.size()-1;i++){
m[v[i]]->left = m[v[i-1]];
m[v[i]]->right = m[v[i+1]];
}
return m[v[0]];
}
};

全部评论

相关推荐

等闲_:感觉有好多地方会被问穿,mysql存储向量这个方案问题应该很大的,如果深问的的话,为什么不用es,不用pg,不用mivus,分块策略是怎么做的,向量化是怎么向量化的,稠密向量还是稀疏向量,再深问余弦相似度,HSWM算法,Bm25算法,为什么不用混合检索或者Rank重排序优化?其他的项目不停机分库分表咋实现的,切库过程中数据有diff的话有没有补偿策略?既然有了分库分表了有没有碰到业务上不好优化的慢sql,让这个sql读从库?而且点评的话,最好自己压测过,要不这个数据也不好解释。现在就27的情况来看,很多同学已经有了中大厂实习,这个节点也会偏向这些有大厂实习的92同学,而且hc也不多,所以坚持海投吧
听劝,我这个简历该怎么改...
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务