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

SEMAN

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

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

    今天參加MS2006年度秋季校園招聘會的筆試第三場,有一個算法題,求一個樹種兩個節(jié)點的最低公共節(jié)點,在網(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) 評論(5)  編輯 收藏 引用

Feedback

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

# 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;
}

  回復  更多評論
  

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

這樣太費解了,不如寫兩個函數(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;
}
因為最后一步僅僅是在pRoot下是否存在pNode1和pNode2,所以還有優(yōu)化的余地  回復  更多評論
  

# re: MS的筆試題目 2006-12-28 23:41 kgha
這樣太費解了,不如寫兩個函數(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;
}
因為最后一步僅僅是在pRoot下是否存在pNode1和pNode2,所以還有優(yōu)化的余地
上面的有點小錯誤,呵呵  回復  更多評論
  

# re: MS的筆試題目 2008-03-07 17:31 521zheng
其實沒有這么麻煩的,
考慮一下二叉查找樹的特點,如果兩個節(jié)點的值都大于或都小于某一個節(jié)點的值,就繼續(xù)遍歷下去,否則返回節(jié)點的值
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;
}  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品乱码久久久久久日本蜜臀 | 久久久夜夜夜| 99re亚洲国产精品| 亚洲国产精品视频一区| 亚洲国产精品国自产拍av秋霞| 国产中文一区二区| 在线精品视频免费观看| 最新国产拍偷乱拍精品 | 韩国精品在线观看| 亚洲高清一区二区三区| 日韩一级精品| 久久精品男女| 亚洲黑丝一区二区| 亚洲视频www| 欧美怡红院视频| 免费观看成人| 国产精品盗摄久久久| 国产情人节一区| 亚洲国产精品www| 亚洲综合视频1区| 免费在线播放第一区高清av| 亚洲人成网站777色婷婷| 亚洲视频狠狠| 久久久爽爽爽美女图片| 欧美无乱码久久久免费午夜一区| 国产欧美精品久久| 日韩视频免费| 久久久噜噜噜久久中文字免| 亚洲国产成人91精品| 日韩午夜黄色| 久久亚洲精品伦理| 国产日韩精品视频一区| 艳妇臀荡乳欲伦亚洲一区| 久久久精品一区| 正在播放亚洲一区| 欧美精品在线一区二区三区| 国产一级精品aaaaa看| 久久蜜桃香蕉精品一区二区三区| 久久综合九色综合欧美就去吻| 久久爱另类一区二区小说| 亚洲精品中文字幕有码专区| 久久久精品久久久久| 亚洲日本一区二区| 国产亚洲精品久久久久久| 欧美在线观看你懂的| 亚洲视频成人| 一区二区三区**美女毛片 | 亚洲激情二区| 国产精品卡一卡二卡三| 久久久久女教师免费一区| 性伦欧美刺激片在线观看| 欧美一区二区视频在线观看2020| 亚洲欧洲一区二区三区| 国产精品综合av一区二区国产馆| 久久不见久久见免费视频1| 西西人体一区二区| 国产精品久久久久久久久久妞妞| 国产精品国产三级国产aⅴ入口| 国产三级精品在线不卡| 一本大道久久精品懂色aⅴ| 日韩视频永久免费观看| 亚洲二区在线视频| 国产一区二区精品在线观看| 国产欧美亚洲一区| 一区二区三区中文在线观看 | 91久久精品美女| 欧美国产极速在线| 国产午夜精品视频| 欧美日韩在线电影| 亚洲国产一二三| 亚洲欧美日韩在线播放| 亚洲国产三级网| 亚洲欧美日韩精品久久亚洲区| 一本色道久久88精品综合| 在线国产精品播放| 在线看片第一页欧美| 黑丝一区二区三区| 尹人成人综合网| 亚洲网站视频| 日韩一区二区精品| 欧美电影免费观看大全| 麻豆国产精品777777在线| 国产精品亚洲精品| 黑人巨大精品欧美一区二区| 亚洲国产成人精品久久久国产成人一区 | 亚洲国产小视频| 在线日韩欧美| 久久精品一区| 免费看成人av| 亚洲欧美日韩在线| 午夜在线一区二区| 亚洲国产成人久久| 欧美一级午夜免费电影| 亚洲一区二区精品| 亚洲欧洲在线播放| 亚洲国产精品久久久久秋霞不卡| 日韩视频在线免费| 亚洲美女福利视频网站| 久久尤物视频| 亚洲女人天堂av| 欧美日韩视频专区在线播放 | 日韩一级欧洲| 亚洲第一天堂av| 欧美成人精品高清在线播放| 亚洲欧美国产va在线影院| 国产毛片精品国产一区二区三区| 久久久夜夜夜| 欧美精品亚洲精品| 亚洲无线观看| 久久gogo国模裸体人体| 亚洲一级片在线看| 欧美一区二区三区免费大片| 国产一区在线免费观看| 欧美在线一二三区| 久久精品日韩欧美| 国产在线视频欧美| 久久人91精品久久久久久不卡| 亚洲欧美综合国产精品一区| 亚洲精选在线观看| 亚洲图片欧美一区| 国产精品乱码妇女bbbb| 久久久久国产精品一区三寸 | 国产精品影视天天线| 国产综合精品一区| 一本色道久久| 久久久一本精品99久久精品66| 亚洲永久字幕| 欧美久久成人| 99riav1国产精品视频| 国产精品色一区二区三区| 欧美大香线蕉线伊人久久国产精品| 国产欧美91| 久久福利资源站| 亚洲欧美成人网| 亚洲精品欧美极品| 蜜臀久久99精品久久久画质超高清| 久久精品国产亚洲一区二区| 国产精品九九| 亚洲欧美成人网| 久久久噜噜噜久久人人看| 一区二区亚洲精品国产| 国产精品人人做人人爽人人添| 小黄鸭精品aⅴ导航网站入口| 亚洲第一网站| 亚洲女女女同性video| 国产精品久久91| 欧美激情按摩在线| 一本大道久久精品懂色aⅴ| 亚洲欧美日韩国产成人精品影院 | 在线不卡视频| 欧美精品二区三区四区免费看视频| 欧美jizzhd精品欧美喷水| 久久精品国产69国产精品亚洲| 亚洲日韩欧美一区二区在线| 国产欧美短视频| 亚洲性xxxx| 免费在线观看精品| 一区二区三区久久网| 免费观看不卡av| 亚洲欧美国产77777| 亚洲天天影视| 欧美韩日一区| 亚洲国产视频直播| 欧美日韩免费精品| 美女视频黄a大片欧美| 欧美精品一区在线播放| 欧美激情一区二区三区在线| 久久精品一区二区国产| 99在线精品视频在线观看| 久久av资源网站| 久热精品视频在线免费观看 | 亚洲韩国日本中文字幕| 欧美电影资源| 亚洲国产欧美国产综合一区 | 亚洲最新在线| 亚洲国产日韩欧美在线动漫| 亚洲激情精品| 亚洲欧美综合一区| 欧美精品一区二区三区久久久竹菊| 欧美暴力喷水在线| 国产精品视频yy9299一区| 激情国产一区| 一本一本大道香蕉久在线精品| 欧美高清在线视频观看不卡| 老**午夜毛片一区二区三区| 一本大道久久精品懂色aⅴ| 久久精品国产欧美亚洲人人爽| 一区二区电影免费在线观看| 欧美一级黄色网| 在线国产日韩| 在线中文字幕日韩| 亚洲美女中文字幕| 欧美黄色影院| 欧美高清视频免费观看| 亚洲欧美韩国| 欧美三区不卡| 亚洲人成高清| 亚洲国产精品久久| 欧美精品一区在线| 国产精品99久久久久久久vr|