青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

SEMAN

曾經(jīng)滄海難為水、除卻巫山不是云

C++博客 首頁 新隨筆 聯(lián)系 聚合 管理
  9 Posts :: 3 Stories :: 24 Comments :: 0 Trackbacks

    今天參加MS2006年度秋季校園招聘會(huì)的筆試第三場,有一個(gè)算法題,求一個(gè)樹種兩個(gè)節(jié)點(diǎn)的最低公共節(jié)點(diǎn),在網(wǎng)上Google了一下,看到原題大致這樣的:
      Given the values of two nodes in a *binary search tree*, write a c program to find the lowest common ancestor. You may assume that both values already exist in the tree.

The function prototype is as follows: int FindLowestCommonAncestor(node* root,int value1,int value)
           20
          /  \
         8    22
       /   \
      4     12
           /  \
         10    14
    構(gòu)筑函數(shù): struct TreeNode * FindLowestCommonTreeNode(struct node *pNode,)

Struct TreeNode
{
   int Data;
   TreeNode *pLeft, *pRight;
}

FindLowestAncestor(Struct TreeNode *pRoot, Struct TreeNode *pNode1, Struct TreeNode *pNode2)
{
   if (pRoot==NULL) 
      return NULL;
   if (pRoot==pNode1 && pRoot==pNode2) 
      return pRoot;
   Struct TreeNode *pTemp;
   if (pTemp = FindLowestAncestor(pRoot->pLeft,pNode1,pNode2)) 
      return pTemp;
   if (pTemp = FindLowestAncestor(pRoot->pRight,pNode1,pNode2)) 
      return pTemp;
   if (FindLowestAncestor(pRoot,pNode1,pNode1) && FindLowestAncestor(pRoot,pNo
de2,pNode2)) return pRoot;

   return NULL;
}

posted on 2005-11-14 02:05 味全每日C++ 閱讀(1378) 評(píng)論(5)  編輯 收藏 引用

Feedback

# re: MS的筆試題目 2006-10-22 17:18 小小
更多試題,請?jiān)L問: www.pghome.net/art.html  回復(fù)  更多評(píng)論
  

# re: MS的筆試題目 2006-12-28 23:23 kgha
FindLowestAncestor(Struct TreeNode *pRoot, Struct TreeNode *pNode1, Struct TreeNode *pNode2)
{
if (pRoot==NULL)
return NULL;
if (pRoot==pNode1 && pRoot==pNode2)
return pRoot;
Struct TreeNode *pTemp;
if (pTemp = FindLowestAncestor(pRoot->pLeft,pNode1,pNode2))
return pTemp;
if (pTemp = FindLowestAncestor(pRoot->pRight,pNode1,pNode2))
return pTemp;
if (FindLowestAncestor(pRoot,pNode1,pNode1) && FindLowestAncestor(pRoot,pNo
de2,pNode2)) return pRoot;

return NULL;
}

  回復(fù)  更多評(píng)論
  

# re: MS的筆試題目 2006-12-28 23:37 kgha

這樣太費(fèi)解了,不如寫兩個(gè)函數(shù)直觀:
FindLowestAncestor(Struct TreeNode *pRoot, Struct TreeNode *pNode1, Struct TreeNode *pNode2)
{
if (pRoot==NULL)
return NULL;
if (pRoot==pNode1 && pRoot==pNode2)
return pRoot;
Struct TreeNode *pTemp;
if (pTemp = FindLowestAncestor(pRoot->pLeft,pNode1,pNode2))
return pTemp;
if (pTemp = FindLowestAncestor(pRoot->pRight,pNode1,pNode2))
return pTemp;
if (FindNode(pRoot,pNode1) && FindLowestAncestor(pRoot,pNo
de2)) return pRoot;
return NULL;
}
struct TreeNode * FindNode(Struct TreeNode *pRoot, Struct TreeNode *pNode)
{
if(pNode在pRoot下)
{
return pRoot;
}
return NULL;
}
因?yàn)樽詈笠徊絻H僅是在pRoot下是否存在pNode1和pNode2,所以還有優(yōu)化的余地  回復(fù)  更多評(píng)論
  

# re: MS的筆試題目 2006-12-28 23:41 kgha
這樣太費(fèi)解了,不如寫兩個(gè)函數(shù)直觀:
FindLowestAncestor(Struct TreeNode *pRoot, Struct TreeNode *pNode1, Struct TreeNode *pNode2)
{
if (pRoot==NULL)
return NULL;
if (pRoot==pNode1 && pRoot==pNode2)
return pRoot;
Struct TreeNode *pTemp;
if (pTemp = FindLowestAncestor(pRoot->pLeft,pNode1,pNode2))
return pTemp;
if (pTemp = FindLowestAncestor(pRoot->pRight,pNode1,pNode2))
return pTemp;
if (FindNode(pRoot,pNode1) && FindNode(pRoot,pNo
de2)) return pRoot;
return NULL;
}
struct TreeNode * FindNode(Struct TreeNode *pRoot, Struct TreeNode *pNode)
{
if(pNode在pRoot下)
{
return pRoot;
}
return NULL;
}
因?yàn)樽詈笠徊絻H僅是在pRoot下是否存在pNode1和pNode2,所以還有優(yōu)化的余地
上面的有點(diǎn)小錯(cuò)誤,呵呵  回復(fù)  更多評(píng)論
  

# re: MS的筆試題目 2008-03-07 17:31 521zheng
其實(shí)沒有這么麻煩的,
考慮一下二叉查找樹的特點(diǎn),如果兩個(gè)節(jié)點(diǎn)的值都大于或都小于某一個(gè)節(jié)點(diǎn)的值,就繼續(xù)遍歷下去,否則返回節(jié)點(diǎn)的值
int FindLowesCommonNode(root * node , int a, int b)
{
if(a<=node.value && b<=node.value)
return FindLowesCommonNode(node->left, a,b);
if(a>=node.value && b>=node.value)
return FindLowesCommonNode(node->right, a,b);
return root.value;
}  回復(fù)  更多評(píng)論
  


只有注冊用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲免费小视频| 国产精品免费一区豆花| 国产亚洲欧美另类一区二区三区| 亚洲夜晚福利在线观看| 欧美国产日韩精品免费观看| 你懂的视频一区二区| 亚洲国产岛国毛片在线| 欧美国产极速在线| 欧美成人精品三级在线观看| 日韩视频免费在线观看| 性做久久久久久| 黄网动漫久久久| 欧美午夜在线观看| 久久精品91久久香蕉加勒比| 亚洲国产高清自拍| 午夜精品福利一区二区蜜股av| 久久色中文字幕| 亚洲激情视频在线| 欧美色综合网| 久久久久www| 一本到高清视频免费精品| 久久电影一区| aa成人免费视频| 国产综合色在线| 欧美性猛交xxxx乱大交蜜桃| 欧美无砖砖区免费| 国产三级欧美三级日产三级99| 久久久久久网站| 嫩草影视亚洲| 久久午夜精品| 欧美高清视频在线| 久久综合激情| 日韩视频一区二区三区在线播放免费观看| 亚洲精选久久| 亚洲国产精品热久久| 欧美在线视频不卡| 久久伊人亚洲| 亚洲乱码视频| 亚洲欧美激情视频在线观看一区二区三区| 亚洲国产一区二区三区高清 | 一本色道**综合亚洲精品蜜桃冫| 亚洲深夜福利在线| 亚洲精品一区中文| 亚洲国产精品电影| 欧美亚洲在线观看| 亚洲日韩欧美一区二区在线| 欧美 日韩 国产 一区| 亚洲一级片在线观看| 一区二区三区视频在线观看| 麻豆精品网站| 欧美日韩视频在线第一区| 欧美1区2区视频| 韩国av一区二区三区在线观看| 狠狠久久亚洲欧美专区| 亚洲视频在线免费观看| 亚洲成人在线视频播放 | 久久av二区| 一区二区电影免费在线观看| 这里只有精品丝袜| 亚洲高清资源综合久久精品| 欧美在线一区二区| 国产视频不卡| 久久免费视频一区| 久久精品国产第一区二区三区最新章节 | 亚洲一级电影| 国产精品久久久久一区| 亚洲一区二区三区乱码aⅴ| 亚洲精品你懂的| 狠狠入ady亚洲精品| 午夜精品亚洲| 亚洲伊人观看| 久久成人18免费观看| 国产精品电影在线观看| 国产欧美日韩三区| 在线成人h网| 亚洲一二三区在线| 亚洲精品国产欧美| 欧美激情视频网站| 国产精品自拍在线| 亚洲欧洲综合另类| 性视频1819p久久| 亚洲一区二区三区视频| 国产免费成人在线视频| 久久久久久一区二区三区| 久久深夜福利| 一区二区三区日韩精品视频| 在线亚洲成人| 欧美电影免费观看大全| 日韩视频久久| 亚洲欧美日韩国产一区| 精品成人在线视频| 亚洲国产精品一区二区www在线| 欧美精品一区二| 欧美永久精品| 亚洲精品美女在线观看| 欧美视频在线观看一区二区| 欧美在线日韩| 美乳少妇欧美精品| 亚洲免费在线电影| 久久久精彩视频| 国产精品无码专区在线观看| 亚洲日本欧美天堂| 久久免费视频观看| 欧美极品在线视频| 香蕉乱码成人久久天堂爱免费| 久久国产一区| 亚洲欧美日韩另类| 老鸭窝91久久精品色噜噜导演| 一区二区精品| 久久免费高清视频| 午夜精品久久久99热福利| 亚洲高清视频在线| 国产精品美女久久久久久久| 久久亚洲精选| 国产欧美日韩综合一区在线观看| 亚洲激情啪啪| 欧美成人一区二免费视频软件| 亚洲一区二区三区在线播放| 久久视频在线免费观看| 欧美在线视频观看| 欧美激情自拍| 亚洲成色999久久网站| 国产欧美另类| 午夜视频在线观看一区二区| 亚洲一区二区精品| 欧美福利在线观看| 男女激情视频一区| 国产最新精品精品你懂的| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲国产专区| 欧美天堂亚洲电影院在线播放| 另类春色校园亚洲| 久久久精品欧美丰满| 亚洲系列中文字幕| 欧美激情综合网| 亚洲国产精品热久久| 亚洲国产精品久久人人爱蜜臀 | 欧美与黑人午夜性猛交久久久| 欧美xart系列高清| 欧美激情第8页| 欧美三级视频在线播放| 亚洲黄色大片| 日韩视频在线播放| 亚洲欧洲久久| 亚洲美女在线视频| 欧美日韩精品三区| 欧美在线观看一二区| 国产精品久99| 午夜精品偷拍| 老司机久久99久久精品播放免费| 在线观看av一区| 欧美精品三区| 在线中文字幕一区| 欧美在线视频观看免费网站| 精品电影一区| 欧美精品久久久久久久久久| 亚洲美女91| 性色av一区二区三区红粉影视| 国产亚洲欧美一区二区三区| 欧美一级久久| 亚洲制服欧美中文字幕中文字幕| 亚洲一区二区在线播放| 欧美在线精品免播放器视频| 国产一区二区三区在线观看视频 | 一区二区不卡在线视频 午夜欧美不卡在 | 在线观看久久av| 欧美日韩麻豆| 午夜激情一区| 亚洲人成在线播放| 午夜精品久久久久久久久久久久久 | 久久久久一区二区三区| 亚洲黄色在线观看| 国产精品国产三级国产普通话蜜臀 | 免费一级欧美在线大片| 香蕉久久国产| 伊人久久大香线| 欧美多人爱爱视频网站| 夜夜嗨av一区二区三区中文字幕 | 欧美国产日韩视频| 亚洲欧美日韩精品久久| 老司机午夜精品视频| 中文有码久久| 亚洲高清不卡在线| 国产精品久久久久久久久久久久久久| 久久成人18免费网站| 亚洲毛片在线看| 蜜臀a∨国产成人精品| 亚洲欧美成人精品| 日韩一二三区视频| 很黄很黄激情成人| 国产精品久久久久久久久久久久久 | 免费成人你懂的| 午夜在线视频一区二区区别| 亚洲精品美女久久7777777| 美女久久一区| 久久夜色精品亚洲噜噜国产mv| 亚洲欧美日韩国产中文| 一区二区三区不卡视频在线观看| 在线观看欧美日本| 国内欧美视频一区二区|