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

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

C語言判定一棵二叉樹是否為二叉搜索樹的方法分析

2020-05-23 13:28:02
字體:
來源:轉載
供稿:網友

本文實例講述了C語言判定一棵二叉樹是否為二叉搜索樹的方法。分享給大家供大家參考,具體如下:

問題

給定一棵二叉樹,判定該二叉樹是否是二叉搜索樹(Binary Search Tree)?

解法1:暴力搜索

首先說明一下二叉樹和二叉搜索樹的區別。二叉樹指這樣的樹結構,它的每個結點的孩子數目最多為2個;二叉搜索樹是一種二叉樹,但是它有附加的一些約束條件,這些約束條件必須對每個結點都成立:

  • 結點node的左子樹所有結點的值都小于node的值。
  • 結點node的右子樹所有結點的值都大于node的值。
  • 結點node的左右子樹同樣都必須是二叉搜索樹。

該問題在面試中也許經常問到,考察的是對二叉搜索樹定義的理解。初看這個問題,也許會想這樣來實現:

假定當前結點值為k。對于二叉樹中每個結點,判斷其左孩子的值是否小于k,其右孩子的值是否大于k。如果所有結點都滿足該條件,則該二叉樹是一棵二叉搜索樹。

很不幸的是,這個算法是錯誤的??紤]下面的二叉樹,它符合上面算法的條件,但是它不是一棵二叉搜索樹。

     10
   /  /
  5   15     -------- binary tree (1)
     /  /
    6    20

那么,根據二叉搜索樹的定義,可以想到一種暴力搜索的方法來判定二叉樹是否為二叉搜索樹。

假定當前結點值為k。則對于二叉樹中每個結點,其左子樹所有結點的值必須都小于k,其右子樹所有結點的值都必須大于k。

暴力搜索算法代碼如下,雖然效率不高,但是它確實能夠完成工作。該解法最壞情況復雜度為O(n^2),n為結點數目。(當所有結點都在一邊的時候出現最壞情況)

/*判斷左子樹的結點值是否都小于val*/bool isSubTreeLessThan(BinaryTree *p, int val){ if (!p) return true; return (p->data < val &&     isSubTreeLessThan(p->left, val) &&     isSubTreeLessThan(p->right, val));}/*判斷右子樹的結點值是否都大于val*/bool isSubTreeGreaterThan(BinaryTree *p, int val){ if (!p) return true; return (p->data > val &&     isSubTreeGreaterThan(p->left, val) &&     isSubTreeGreaterThan(p->right, val));}/*判定二叉樹是否是二叉搜索樹*/bool isBSTBruteForce(BinaryTree *p){ if (!p) return true; return isSubTreeLessThan(p->left, p->data) &&     isSubTreeGreaterThan(p->right, p->data) &&     isBSTBruteForce(p->left) &&     isBSTBruteForce(p->right);}

一個類似的解法是:對于結點node,判斷其左子樹最大值是否大于node的值,如果是,則該二叉樹不是二叉搜索樹。如果不是,則接著判斷右子樹最小值是否小于或等于node的值,如果是,則不是二叉搜索樹。如果不是則接著遞歸判斷左右子樹是否是二叉搜索樹。(代碼中的maxValue和minValue函數功能分別是返回二叉樹中的最大值和最小值,這里假定二叉樹為二叉搜索樹,實際返回的不一定是最大值和最小值)

int isBST(struct node* node){ if (node==NULL) return(true); //如果左子樹最大值>=當前node的值,則返回false if (node->left!=NULL && maxValue(node->left) >= node->data)  return(false); // 如果右子樹最小值<=當前node的值,返回false if (node->right!=NULL && minValue(node->right) <= node->data)  return(false); // 如果左子樹或者右子樹不是BST,返回false if (!isBST(node->left) || !isBST(node->right))  return(false); // 通過所有測試,返回true return(true);}

解法2:更好的解法

以前面提到的binary tree(1)為例,當我們從結點10遍歷到右結點15時,我們知道右子樹結點值肯定都在10和+INFINITY(無窮大)之間。當我們遍歷到結點15的左孩子結點6時,我們知道結點15的左子樹結點值都必須在10到15之間。顯然,結點6不符合條件,因此它不是一棵二叉搜索樹。該算法代碼如下:

int isBST2(struct node* node){   return(isBSTUtil(node, INT_MIN, INT_MAX));}/*給定的二叉樹是BST則返回true,且它的值 >min 以及 < max.*/int isBSTUtil(struct node* node, int min, int max){   if (node==NULL) return(true);   // 如果不滿足min和max約束,返回false   if (node->data<=min || node->data>=max) return(false);   // 遞歸判斷左右子樹是否滿足min和max約束條件   return     isBSTUtil(node->left, min, node->data) &&     isBSTUtil(node->right, node->data, max)   );}

由于該算法只需要訪問每個結點1次,因此時間復雜度為O(n),比解法1效率高很多。

解法3:中序遍歷算法

因為一棵二叉搜索樹的中序遍歷后其結點值是從小到大排好序的,所以依此給出下面的解法。該解法時間復雜度也是O(n)。

bool isBSTInOrder(BinaryTree *root){ int prev = INT_MIN; return isBSTInOrderHelper(root, prev);}/*該函數判斷二叉樹p是否是一棵二叉搜索樹,且其結點值都大于prev*/bool isBSTInOrderHelper(BinaryTree *p, int& prev){ if (!p) return true; if (isBSTInOrderHelper(p->left, prev)) { // 如果左子樹是二叉搜索樹,且結點值都大于prev  if (p->data > prev) { //判斷當前結點值是否大于prev,因為此時prev已經設置為已經中序遍歷過的結點的最大值。   prev = p->data;   return isBSTInOrderHelper(p->right, prev); //若結點值大于prev,則設置prev為當前結點值,并判斷右子樹是否二叉搜索樹且結點值都大于prev。  } else {   return false;  } } else {  return false; }}

希望本文所述對大家C語言程序設計有所幫助。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91欧美精品午夜性色福利在线| 中文字幕日韩免费视频| 国产精品一区二区久久久| 亚洲国产日韩欧美在线动漫| 国产精品久久久久久亚洲调教| 一本久久综合亚洲鲁鲁| 69影院欧美专区视频| 欧美日韩一二三四五区| 色先锋资源久久综合5566| 97人人爽人人喊人人模波多| 国产一区二区日韩精品欧美精品| 98午夜经典影视| 91精品国产自产在线观看永久| 2025国产精品视频| 欧美性猛交xxxx乱大交极品| 亚洲一区二区三区乱码aⅴ蜜桃女| 欧美性在线观看| 日韩精品在线视频美女| 97色在线观看免费视频| 91香蕉嫩草神马影院在线观看| 亚洲自拍偷拍色片视频| 欧美人与性动交| 国产成人精品免费视频| 亚洲成人999| 疯狂蹂躏欧美一区二区精品| 92版电视剧仙鹤神针在线观看| 亚洲一区二区在线播放| 久久视频这里只有精品| 91地址最新发布| 亚洲18私人小影院| 色噜噜亚洲精品中文字幕| 欧美成人免费在线观看| 日韩经典中文字幕| 亚洲成人三级在线| 2019亚洲日韩新视频| 亚洲网站在线播放| 国产剧情久久久久久| 91日本在线视频| 亚洲欧美另类人妖| 日本伊人精品一区二区三区介绍| 成人午夜在线视频一区| 日本欧美爱爱爱| 中日韩午夜理伦电影免费| 日韩欧美精品网址| 欧美疯狂做受xxxx高潮| 日韩美女免费视频| 亚洲激情电影中文字幕| 国产一区二区三区日韩欧美| 日韩性xxxx爱| 精品一区二区亚洲| 亚洲精品mp4| 亚洲精品按摩视频| 91在线网站视频| 九色精品美女在线| 91九色在线视频| 欧美精品久久久久| 在线视频日本亚洲性| 亚洲美女视频网| 欧美一区二区三区精品电影| 国产97在线播放| 庆余年2免费日韩剧观看大牛| 国产欧美一区二区白浆黑人| 国产精品露脸av在线| 一区二区三区日韩在线| 久久人人爽人人爽人人片av高请| 2019国产精品自在线拍国产不卡| 97精品免费视频| 国产69久久精品成人看| 韩曰欧美视频免费观看| 欧美亚洲另类在线| 亚洲第一天堂av| 九色精品美女在线| 97色在线观看免费视频| 成人高h视频在线| 亚洲国产精品电影| 亚洲精品之草原avav久久| 国产精品丝袜久久久久久高清| 国产精品极品尤物在线观看| 亚洲国产日韩精品在线| 亚洲天堂av在线免费观看| 日韩在线精品一区| 久久99久国产精品黄毛片入口| 中文亚洲视频在线| 国内精品久久久久久久久| 日韩在线资源网| 国产经典一区二区| 中文字幕亚洲二区| 4438全国亚洲精品在线观看视频| 亚洲欧美一区二区三区在线| 国产欧美亚洲精品| 久久99精品久久久久久琪琪| 久久色在线播放| 日韩欧美在线视频观看| 色吧影院999| 亚洲成人av片| 日韩在线不卡视频| 91最新国产视频| 国产精品精品久久久| 最近2019中文字幕mv免费看| 欧美日韩一区二区在线播放| 日韩中文字幕网址| 欧美电影在线观看完整版| 国产精品678| xxxx性欧美| 久久国产加勒比精品无码| 国产精品jizz在线观看麻豆| 中文字幕九色91在线| 中文字幕亚洲欧美日韩高清| 国产精品视频yy9099| 色妞在线综合亚洲欧美| 国产视频综合在线| 亚洲精品97久久| 97精品国产97久久久久久春色| 欧美成人剧情片在线观看| 久久久99久久精品女同性| 日韩成人网免费视频| 亚洲人成欧美中文字幕| 国产精品99久久99久久久二8| 国产精品嫩草影院一区二区| 热久久视久久精品18亚洲精品| 日韩精品视频免费| 日韩不卡中文字幕| 欧美黑人巨大精品一区二区| 中文字幕自拍vr一区二区三区| 亚洲国产第一页| 久久久久久久久久久亚洲| 91久久精品国产91性色| 日韩成人在线免费观看| 狠狠干狠狠久久| 色与欲影视天天看综合网| 成人在线视频网| 成人精品一区二区三区电影黑人| 国产精品美女久久久免费| 黄色一区二区在线观看| 国产丝袜一区二区三区| 国产精品爽爽爽爽爽爽在线观看| 九九热99久久久国产盗摄| 国产欧美婷婷中文| 日韩av日韩在线观看| 亚洲精品免费一区二区三区| 午夜精品蜜臀一区二区三区免费| 九九精品在线观看| 欧美一级视频一区二区| 亚洲成成品网站| 欧美综合在线观看| 555www成人网| 国产精品中文字幕久久久| 日韩精品极品在线观看播放免费视频| 97在线视频一区| 色黄久久久久久| 久久综合免费视频影院| 日韩欧美在线国产| 国产精品久久久久久久一区探花| 亚洲激情电影中文字幕| 国产精品三级美女白浆呻吟| 精品国产一区二区三区久久狼黑人| 久久精品国产综合| 色婷婷综合久久久久中文字幕1| 久久在线观看视频| 2018国产精品视频| 不用播放器成人网| 国产精品aaaa| 亚洲黄色av女优在线观看| 国产精品免费久久久久影院|