D*0
2 楼
镇上的几个主妇好不容易组织了一次不带小孩的疯狂之夜,畅饮之后两个主妇结伴走路
回家。走到一半两人都感觉到内急,恰巧边上小道是墓地,两个人拐弯进去,Shelly尿
完后脱下内裤擦干净,Jamie舍不得弄脏内裤,刚好她边上是个新墓,她借着月光解下
几个系鲜花的丝带用。
第二天是周末,Shelly的老公大早上打电话给Jamie老公,“昨晚到底发生了什么事?
我太太回家竟然裙下光着,我有很不好的感觉。。。”
“是啊,我也想问,都不大好张口,我刚才起床,看见Jamie的屁股上有个不沾胶的软
卡片,上写“消防队全体同仁敬上””
回家。走到一半两人都感觉到内急,恰巧边上小道是墓地,两个人拐弯进去,Shelly尿
完后脱下内裤擦干净,Jamie舍不得弄脏内裤,刚好她边上是个新墓,她借着月光解下
几个系鲜花的丝带用。
第二天是周末,Shelly的老公大早上打电话给Jamie老公,“昨晚到底发生了什么事?
我太太回家竟然裙下光着,我有很不好的感觉。。。”
“是啊,我也想问,都不大好张口,我刚才起床,看见Jamie的屁股上有个不沾胶的软
卡片,上写“消防队全体同仁敬上””
i*y
4 楼
尿尿为什么要擦?
g*u
5 楼
假设该元素不在BST中,首先找到最后一个比该元素小的节点,然后找到第一个比该元素大的节点,返回2个节点中离目标最近的节点。
下面是实现,等待拍砖。
node * findClose(node *root, int value)
{
if(!root)
return NULL;
node * smaller=findLastSmaller(root, value);
node * greater=findFirstGrearer(root, value);
//we will also need to check both of smaller and greater are not NULL
return value-smaller->value< greater->value - value?smaller:greater;
}
node * findLastSmaller(node * root, int value)
{
if(!root)
return NULL;
node * result=NULL;
while(root)
{
if(root->value >= value)
root=root->left;
else{
result=root;
root=root->right;
}
}
return result;
}
node * findFirstGreater(node * root, int value)
{
if(!root)
return NULL;
node * result=NULL;
while(root)
{
if(root->value<=value)
root=root->right;
else{
result=root;
root=root->left;
}
}
return result;
}
时间复杂度是 O(log n), 空间复杂度是O(1)
还有一个做法就是in-order visit,然后做binary search, 找到该元素的区间,然后寻找目标节点。 时间复杂度是一样的,但空间复杂度就是 O(n)了
【在 s******n 的大作中提到】
: 突然想到一个题目,找到BST中离目标最近的那个数
: 大家又什么好解法?
相关阅读
今天是翁帆姐40大寿,庆祝一下 (转载)床铺又大嘴巴了美国研究发现转基因就是好520潘金莲毒死武大郎?Re: 请新葱回答一个问题,很严肃 (转载)哇,美颜相机涉嫌种族歧视啊莱斯特城夺冠后,我就拿着三瓶酒和一包避孕套来到了莱斯特城国内都以大声讲话为荣为什么这个mm显得很有风韵?一些笑话熟透了! (转载)大仙们,来!看看我大MIT是否能有比这翻译还牛X的!Enlon Musk痔疮膏,OK!贱人笑话,虽然我们都很贱,但是贱的有节操 Zz笑话合集,好骨头 [转]《愤怒的小鸟》就是一部教导小孩警惕绿教的政治片! (转载)人活着最重要是开心(转载)trending in programming fieldWalgreens窘了手抄党章 (转载)