• <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>

            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++ 閱讀(1324) 評論(5)  編輯 收藏 引用

            Feedback

            # re: MS的筆試題目 2006-10-22 17:18 小小
            更多試題,請?jiān)L問: 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)解了,不如寫兩個(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ù)  更多評論
              

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

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

            成人精品一区二区久久| 国内精品久久久久伊人av| 久久久久99精品成人片牛牛影视| 伊人久久大香线焦综合四虎| 久久精品国产WWW456C0M| 欧美激情精品久久久久久| 少妇精品久久久一区二区三区| 国产综合久久久久久鬼色| 久久无码精品一区二区三区| 久久久久久精品免费免费自慰| 久久96国产精品久久久| 久久亚洲中文字幕精品一区四| 日韩乱码人妻无码中文字幕久久| 狠狠人妻久久久久久综合蜜桃| 国产精品久久新婚兰兰| 色综合久久久久网| 久久精品aⅴ无码中文字字幕重口| 国产精品热久久毛片| 久久国产热精品波多野结衣AV| 久久久久亚洲AV成人网| 国产99久久精品一区二区| 无码人妻久久一区二区三区蜜桃 | 久久亚洲国产精品五月天婷| 久久婷婷国产综合精品| 久久久SS麻豆欧美国产日韩| 国产精品女同一区二区久久| 精品久久久久中文字幕日本| 精品人妻伦九区久久AAA片69| 国产精品va久久久久久久| 久久99毛片免费观看不卡 | 99久久婷婷免费国产综合精品| 一日本道伊人久久综合影| 久久九九久精品国产免费直播| 成人综合伊人五月婷久久| 久久国产精品无码一区二区三区 | 久久亚洲AV成人无码国产| 精品多毛少妇人妻AV免费久久| 亚洲国产成人精品女人久久久 | 亚州日韩精品专区久久久| 久久久精品久久久久久 | 精品久久久久久无码专区|