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

SEMAN

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

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

    今天參加MS2006年度秋季校園招聘會的筆試第三場,有一個算法題,求一個樹種兩個節(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++ 閱讀(1377) 評論(5)  編輯 收藏 引用

Feedback

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

# 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ù)  更多評論
  

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

這樣太費(fèi)解了,不如寫兩個函數(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ù)  更多評論
  

# re: MS的筆試題目 2006-12-28 23:41 kgha
這樣太費(fèi)解了,不如寫兩個函數(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)小錯誤,呵呵  回復(fù)  更多評論
  

# re: MS的筆試題目 2008-03-07 17:31 521zheng
其實(shí)沒有這么麻煩的,
考慮一下二叉查找樹的特點(diǎn),如果兩個節(jié)點(diǎn)的值都大于或都小于某一個節(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ù)  更多評論
  


只有注冊用戶登錄后才能發(fā)表評論。
網(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>
            性8sex亚洲区入口| 欧美三级电影网| 亚洲人体偷拍| 久久精品导航| 久久久噜噜噜久久久| 久久精品日韩欧美| 免费91麻豆精品国产自产在线观看| 久久婷婷人人澡人人喊人人爽| 久久亚洲不卡| 欧美高清视频一区二区| 亚洲国产欧美国产综合一区| 日韩一级精品| 久久国产天堂福利天堂| 欧美a级片网站| 国产精品免费一区二区三区在线观看| 国产亚洲福利一区| 亚洲人成在线播放网站岛国| 一区二区三区你懂的| 欧美一区二区三区四区高清 | 久久久综合精品| 欧美成人乱码一区二区三区| 亚洲精品久久久久久久久久久久久 | 欧美性猛交xxxx乱大交蜜桃| 国产精品免费网站在线观看| 黄色影院成人| 在线亚洲+欧美+日本专区| 久久国产天堂福利天堂| 亚洲电影在线观看| 亚洲影院免费观看| 99re视频这里只有精品| 羞羞色国产精品| 久久综合福利| 亚洲美女在线视频| 亚洲免费人成在线视频观看| 卡一卡二国产精品| 国产乱码精品一区二区三区av| 亚洲精品综合精品自拍| 久久久精品日韩欧美| 亚洲精品一区中文| 久久久噜噜噜久久人人看| 99在线热播精品免费99热| 美女日韩在线中文字幕| 国产欧美精品在线| 一区二区三区四区在线| 欧美成人嫩草网站| 欧美日韩伦理在线| 亚洲区国产区| 一区二区三区精品视频| 久久av一区二区| 国产精品国产三级国产专播精品人 | 欧美成人中文| 精品91在线| 久久精品水蜜桃av综合天堂| 亚洲午夜黄色| 欧美日韩一区不卡| 99精品免费视频| 亚洲黄网站在线观看| 久久午夜国产精品| 玉米视频成人免费看| 久久一二三四| 久久久人成影片一区二区三区 | 亚洲一区二区免费| 亚洲欧洲日本在线| 欧美国产日韩一区二区| 亚洲精品国产精品国自产观看| 免费在线亚洲| 久久综合精品一区| 亚洲国产精品毛片| 亚洲国产欧美日韩| 欧美日韩精品福利| 亚洲一区二区av电影| 亚洲一区二区三区四区在线观看| 国产精品黄视频| 午夜久久黄色| 久久成人这里只有精品| 在线高清一区| 欲色影视综合吧| 欧美福利视频一区| 欧美国产一区二区在线观看| 99re在线精品| 亚洲欧美日韩网| 黄色另类av| 亚洲欧洲日本mm| 国产精品午夜在线观看| 久久先锋资源| 欧美精品一区三区在线观看| 亚洲欧美一区二区三区久久| 久久成人免费日本黄色| 亚洲精品乱码久久久久久日本蜜臀 | 一区二区三区国产盗摄| 亚洲婷婷在线| 在线日韩一区二区| 亚洲精品少妇30p| 国产欧美视频一区二区三区| 欧美国产日韩精品免费观看| 欧美色播在线播放| 久色成人在线| 国产精品国码视频| 嫩草国产精品入口| 欧美少妇一区| 欧美国产三级| 国产真实乱偷精品视频免| 亚洲激情国产| 韩国福利一区| 中文在线一区| 亚洲精品久久久久中文字幕欢迎你 | 国产一区二区日韩精品欧美精品| 欧美黑人在线播放| 国产精品影音先锋| 亚洲人成欧美中文字幕| 韩国成人精品a∨在线观看| 一本色道久久99精品综合| 尤物99国产成人精品视频| 亚洲女爱视频在线| 一区二区三区欧美在线| 毛片一区二区三区| 久久精品国产精品亚洲| 国产精品v欧美精品∨日韩| 亚洲高清不卡av| 激情综合网址| 欧美在线观看一区二区| 亚洲永久免费视频| 欧美精品1区2区3区| 欧美激情一区二区三区| 亚洲大片一区二区三区| 久久本道综合色狠狠五月| 欧美一区激情视频在线观看| 国产精品家教| 这里只有精品视频在线| 夜夜嗨一区二区| 欧美高清在线播放| 欧美va亚洲va香蕉在线| 激情六月婷婷综合| 久久综合久色欧美综合狠狠| 国产精品综合| 亚洲一区二区免费在线| 亚洲欧美日韩中文播放| 国产精品二区在线观看| 一区二区欧美国产| 亚洲综合精品| 国产精品一区二区在线| 亚洲一区二区四区| 欧美在线视频免费播放| 国产热re99久久6国产精品| 亚洲男人的天堂在线| 久久精品国产999大香线蕉| 国产在线视频欧美一区二区三区| 欧美在线观看网站| 蜜桃久久av一区| 亚洲日本久久| 欧美三级乱人伦电影| 亚洲伊人色欲综合网| 久久成人精品| 1769国内精品视频在线播放| 欧美电影在线播放| 99视频国产精品免费观看| 欧美一级片久久久久久久| 国产欧美一区二区三区沐欲| 久久精品夜夜夜夜久久| 亚洲黄色免费| 亚洲欧美一区在线| 精品96久久久久久中文字幕无| 久久综合九色99| 一本色道久久| 欧美中文字幕在线观看| 亚洲成人影音| 欧美日韩综合网| 久久国产精品高清| 亚洲精品在线视频观看| 久久精品国产一区二区三区| 亚洲黄网站在线观看| 国产精品高清在线| 久久噜噜噜精品国产亚洲综合 | 亚洲国产日本| 新67194成人永久网站| 亚洲国产精品悠悠久久琪琪| 欧美日韩一区二区免费在线观看| 亚洲欧美日韩精品在线| 欧美激情中文不卡| 欧美一级久久久| 亚洲欧洲一区二区天堂久久| 国产精品免费一区二区三区在线观看 | 亚洲第一页在线| 亚洲欧美在线高清| 亚洲欧洲精品成人久久奇米网| 欧美三区美女| 农夫在线精品视频免费观看| 香蕉成人啪国产精品视频综合网| 亚洲欧洲在线免费| 久久综合影音| 亚洲欧美日本精品| 99爱精品视频| 亚洲人成7777| 亚洲国产精品t66y| 国产一区二区三区在线免费观看 | 亚洲欧美综合国产精品一区| 亚洲国产乱码最新视频| 国产欧美日韩精品专区| 欧美日韩直播| 欧美日韩免费高清|