亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

C++實現尋找最低公共父節點的方法

2020-01-26 15:18:03
字體:
來源:轉載
供稿:網友

本文實例講述了C++實現尋找最低公共父節點的方法,是數據結構中二叉樹的經典算法。分享給大家供大家參考。具體方法如下:

最低公共父節點,意思很好理解。

思路1:最低公共父節點滿足這樣的條件:兩個節點分別位于其左子樹和右子樹,那么定義兩個bool變量,leftFlag和rightFlag,如果在左子樹中,leftFlag為true,如果在右子樹中,rightFlag為true,僅當leftFlag == rightFlag == true時,才能滿足條件。

實現代碼如下:

#include <iostream>using namespace std;struct Node{ Node(int i = 0, Node *pLeft = NULL, Node *pRight = NULL) : data(i), left(pLeft), right(pRight) {} Node *left; Node *right; int data;};Node *constructNode(Node **pNode1, Node **pNode2){ Node *node12 = new Node(12); Node *node11 = new Node(11); Node *node10 = new Node(10); Node *node9 = new Node(9, NULL, node12); Node *node8 = new Node(8, node11, NULL); Node *node7 = new Node(7); Node *node6 = new Node(6); Node *node5 = new Node(5, node8, node9); Node *node4 = new Node(4, node10); Node *node3 = new Node(3, node6, node7); Node *node2 = new Node(2, node4, node5); Node *node1 = new Node(1, node2, node3); *pNode1 = node6; *pNode2 = node12; return node1;}bool isNodeIn(Node *root, Node *node1, Node *node2){ if (node1 == NULL || node2 == NULL) { throw("invalid node1 and node2"); return false; } if (root == NULL) return false; if (root == node1 || root == node2) { return true; } else { return isNodeIn(root->left, node1, node2) || isNodeIn(root->right, node1, node2); }}Node *lowestFarther(Node *root, Node *node1, Node *node2){ if (root == NULL || node1 == NULL || node2 == NULL || node1 == node2) { return NULL; }  bool leftFlag = false; bool rightFlag = false; leftFlag = isNodeIn(root->left, node1, node2); rightFlag = isNodeIn(root->right, node1, node2); if (leftFlag == true && rightFlag == true) { return root; } else if (leftFlag == true) { return lowestFarther(root->left, node1, node2); } else { return lowestFarther(root->right, node1, node2); }}void main(){ Node *node1 = NULL; Node *node2 = NULL; Node *root = constructNode(&node1, &node2); cout << "node1: " << node1->data << endl; cout << "node2: " << node2->data << endl; cout << "root: " << root->data << endl; Node *father = lowestFarther(root, node1, node2); if (father == NULL) { cout << "no common father" << endl; } else { cout << "father: " << father->data << endl; }}

這類問題在面試的時候常會遇到,對此需要考慮以下情形:

1. node1和node2指向同一節點,這個如何處理
2. node1或node2有不為葉子節點的可能性嗎
3. node1或node2一定在樹中嗎

還要考慮一個效率問題,上述代碼中用了兩個遞歸函數,而且存在不必要的遞歸過程,仔細思考,其實一個遞歸過程足以解決此問題

實現代碼如下:

#include <iostream>using namespace std;struct Node{ Node(int i = 0, Node *pLeft = NULL, Node *pRight = NULL) : data(i), left(pLeft), right(pRight) {} int data; Node *left; Node *right;};Node *constructNode(Node **pNode1, Node **pNode2) {  Node *node12 = new Node(12);  Node *node11 = new Node(11);  Node *node10 = new Node(10);  Node *node9 = new Node(9, NULL, node12);  Node *node8 = new Node(8, node11, NULL);  Node *node7 = new Node(7);  Node *node6 = new Node(6);  Node *node5 = new Node(5, node8, node9);  Node *node4 = new Node(4, node10);  Node *node3 = new Node(3, node6, node7);  Node *node2 = new Node(2, node4, node5);  Node *node1 = new Node(1, node2, node3);  *pNode1 = node6;  *pNode2 = node5;  return node1; }bool lowestFather(Node *root, Node *node1, Node *node2, Node *&dest){ if (root == NULL || node1 == NULL || node2 == NULL || node1 == node2) return false; if (root == node1 || root == node2) return true; bool leftFlag = lowestFather(root->left, node1, node2, dest); bool rightFlag = lowestFather(root->right, node1, node2, dest);  if (leftFlag == true && rightFlag == true) { dest = root; } if (leftFlag == true || rightFlag == true) return true;}int main(){ Node *node1 = NULL; Node *node2 = NULL; Node *root = constructNode(&node1, &node2); bool flag1 = false; bool flag2 = false; Node *dest = NULL; bool flag = lowestFather(root, node1, node2, dest); if (dest != NULL) { cout << "lowest common father: " << dest->data << endl; } else { cout << "no common father!" << endl; } return 0;}

下面再換一種方式的寫法如下:

#include <iostream>using namespace std;struct Node{ Node(int i = 0, Node *pLeft = NULL, Node *pRight = NULL) : data(i), left(pLeft), right(pRight) {} int data; Node *left; Node *right;};Node *constructNode(Node **pNode1, Node **pNode2) {  Node *node12 = new Node(12);  Node *node11 = new Node(11);  Node *node10 = new Node(10);  Node *node9 = new Node(9, NULL, node12);  Node *node8 = new Node(8, node11, NULL);  Node *node7 = new Node(7);  Node *node6 = new Node(6);  Node *node5 = new Node(5, node8, node9);  Node *node4 = new Node(4, node10);  Node *node3 = new Node(3, node6, node7);  Node *node2 = new Node(2, node4, node5);  Node *node1 = new Node(1, node2, node3);  *pNode1 = node11;  *pNode2 = node12;  return node1; }Node* lowestFather(Node *root, Node *node1, Node *node2){ if (root == NULL || node1 == NULL || node2 == NULL || node1 == node2) return NULL; if (root == node1 || root == node2) return root; Node* leftFlag = lowestFather(root->left, node1, node2); Node* rightFlag = lowestFather(root->right, node1, node2); if (leftFlag == NULL) return rightFlag; else if (rightFlag == NULL) return leftFlag; else return root;}int main(){ Node *node1 = NULL; Node *node2 = NULL; Node *root = constructNode(&node1, &node2); bool flag1 = false; bool flag2 = false; Node *dest = NULL; Node* flag = lowestFather(root, node1, node2); if (flag != NULL) { cout << "lowest common father: " << flag->data << endl; } else { cout << "no common father!" << endl; } return 0;}

希望本文所述對大家C++程序算法設計的學習有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
一区国产精品视频| 国产精品视频大全| 久久久黄色av| 亚洲一品av免费观看| 亚洲精品电影久久久| 日韩高清人体午夜| 深夜福利日韩在线看| 国产99视频精品免视看7| 这里只有精品久久| 中文字幕免费精品一区| 久久成人国产精品| 欧美色videos| 国产女精品视频网站免费| 欧美激情乱人伦| 中文字幕欧美专区| 亚洲精品综合精品自拍| 欧美日韩一区二区在线播放| 91欧美精品午夜性色福利在线| 国产精国产精品| 亚洲欧美日韩在线一区| 国产精品美女www爽爽爽视频| 中文字幕日韩在线播放| 国产脚交av在线一区二区| 青青在线视频一区二区三区| 91九色国产在线| 亚洲欧美一区二区精品久久久| 最近2019好看的中文字幕免费| 精品伊人久久97| 欧美大荫蒂xxx| 欧美最顶级的aⅴ艳星| 91精品在线观看视频| 高清欧美一区二区三区| 中文字幕亚洲情99在线| 久久亚洲春色中文字幕| 久久久噜噜噜久噜久久| 成人免费淫片aa视频免费| 欧美日韩国产综合新一区| 欧美成年人视频网站| 久久久噜噜噜久噜久久| 亚洲一区二区三区四区视频| 亚洲奶大毛多的老太婆| 日韩风俗一区 二区| 亚洲欧美日韩中文视频| 国产亚洲视频在线观看| 国产精品视频久久久| 少妇高潮久久77777| 国产综合色香蕉精品| 伊人久久综合97精品| 亚洲最新av在线网站| 亚洲国产精品久久精品怡红院| 中文字幕亚洲综合| 国产精品黄色影片导航在线观看| 久久久欧美一区二区| 久久久精品免费视频| 国产精品久久97| 国产成人av网址| 97视频在线看| 亚洲国产欧美一区二区三区久久| 亚洲美女在线观看| 欧美性猛交xxxx乱大交蜜桃| 精品久久久久久中文字幕一区奶水| 97在线视频免费观看| 成人高清视频观看www| 欧美精品久久久久久久久| 亚洲在线免费看| 成人伊人精品色xxxx视频| 国产精品视频精品视频| 久久久久久亚洲精品| 欧美高清自拍一区| 91免费看片网站| 国产精品爽爽爽爽爽爽在线观看| 91视频国产高清| 久久视频在线直播| 一区二区三区国产在线观看| 欧美极品第一页| 久久亚洲国产成人| 日产精品久久久一区二区福利| 日韩网站免费观看高清| 亚洲美女av在线播放| 亚洲成人久久电影| 日韩精品中文字幕在线播放| 欧美又大又粗又长| 亚洲国产精品一区二区三区| 欧美激情在线视频二区| 色悠悠国产精品| 国产精品大陆在线观看| 日韩高清电影好看的电视剧电影| 国外成人免费在线播放| 亚洲一二在线观看| 亚洲色图在线观看| 成人中文字幕+乱码+中文字幕| 91国产高清在线| 日韩美女在线播放| 视频在线观看一区二区| 少妇激情综合网| 欧美激情综合色| 国产aⅴ夜夜欢一区二区三区| 国产成人精品a视频一区www| 亚洲一区精品电影| 久久中文精品视频| xxav国产精品美女主播| 国产亚洲精品一区二区| 久久精品亚洲国产| 国产精品久久久久久av下载红粉| 亚洲字幕一区二区| 欧美国产高跟鞋裸体秀xxxhd| 亚洲奶大毛多的老太婆| 亚洲欧美国产精品专区久久| 久久久久久免费精品| 欧美日韩午夜剧场| www.欧美三级电影.com| 国产一区二区三区三区在线观看| 亚洲成人久久一区| 一区二区亚洲欧洲国产日韩| 精品国产鲁一鲁一区二区张丽| 亚洲自拍偷拍第一页| 欧美贵妇videos办公室| 亚洲小视频在线| 久久不射热爱视频精品| 国产亚洲精品成人av久久ww| 伊人久久男人天堂| 中文字幕日本欧美| 日韩一二三在线视频播| 成人www视频在线观看| 97人人爽人人喊人人模波多| 午夜精品一区二区三区在线视频| 日韩欧美精品网址| 亚洲精品wwwww| 欧美一级淫片aaaaaaa视频| 国产欧美精品xxxx另类| 欧美国产一区二区三区| 国产亚洲视频在线观看| 成人免费淫片视频软件| 欧美国产日韩中文字幕在线| 亚洲第一免费网站| 国产精品第100页| 日韩精品视频免费在线观看| 色狠狠av一区二区三区香蕉蜜桃| 久久成人亚洲精品| 日本一区二三区好的精华液| 欧美激情图片区| 国产精品极品尤物在线观看| 亚洲国产欧美久久| 在线观看欧美日韩| 51视频国产精品一区二区| 国产精品av网站| 欧美视频一二三| 精品国偷自产在线视频99| 九九热这里只有精品6| 欧美黑人性生活视频| 国产精品精品视频一区二区三区| 欧美成人免费全部观看天天性色| 欧美精品xxx| 日本午夜精品理论片a级appf发布| 91精品在线观| 久久99精品视频一区97| 欧美夫妻性生活视频| 亚洲欧美日韩高清| 国产成人在线一区二区| 日韩成人网免费视频| 国产精选久久久久久| 夜夜躁日日躁狠狠久久88av| 久热精品在线视频| 久久久女人电视剧免费播放下载|