二叉樹粗解

二叉樹是一種每個節(jié)點最好有左右兩個子節(jié)點的樹結(jié)構(gòu)。概念的東西就不倒騰了。意思意思就好。

算法之中,對于二叉樹類的問題 一般使用遞歸的思想去解它。

二叉排序樹/二叉查找樹/二叉搜索樹 這三者都是一個東西,是一種特殊的二叉樹,它滿足下面幾個條件:
1.若左子樹不為空 那么左子樹的所有節(jié)點都小于根節(jié)點
2.若右子樹不為空 那么右子樹的所有節(jié)點都大于根節(jié)點
3.左右子樹分別又是二叉搜索樹
4.整個樹結(jié)構(gòu)中 沒有鍵值相等的兩個節(jié)點

二叉樹類的定義(oc 版)
@interface BTNode : NSObject
@Property (nonatomic, assign) NSInteger value; //值
@property (nonatomic, strong) BTNode *left; //左子節(jié)點
@property (nonatomic, strong) BTNode *right; //右子節(jié)點
@end

二叉樹的創(chuàng)建
/**

  • 創(chuàng)建二叉排序樹
  • 二叉排序樹:左節(jié)點值全部小于根節(jié)點值,右節(jié)點值全部大于根節(jié)點值
  • @param values 數(shù)組
  • @return 二叉樹根節(jié)點
    */
  • (BinaryTreeNode *)createTreeWithValues:(NSArray *)values {

    BinaryTreeNode *root = nil;
    for (NSInteger i=0; i<values.count; i++) {
    NSInteger value = [(NSNumber *)[values objectAtIndex:i] integerValue];
    root = [BinaryTree addTreeNode:root value:value];
    }
    return root;
    }

/**

  • 向二叉排序樹節(jié)點添加一個節(jié)點
  • @param treeNode 根節(jié)點
  • @param value 值
  • @return 根節(jié)點
    */
  • (BinaryTreeNode *)addTreeNode:(BinaryTreeNode *)treeNode value:(NSInteger)value {
    //根節(jié)點不存在,創(chuàng)建節(jié)點
    if (!treeNode) {
    treeNode = [BinaryTreeNode new];
    treeNode.value = value;
    NSLog(@"node:%@", @(value));
    }
    else if (value <= treeNode.value) {
    NSLog(@"to left");
    //值小于根節(jié)點,則插入到左子樹
    treeNode.leftNode = [BinaryTree addTreeNode:treeNode.leftNode value:value];
    }
    else {
    NSLog(@"to right");
    //值大于根節(jié)點,則插入到右子樹
    treeNode.rightNode = [BinaryTree addTreeNode:treeNode.rightNode value:value];
    }

    return treeNode;
    }

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 什么是二叉樹? 在計算機科學中,二叉樹是每個節(jié)點最多有兩個子樹的樹結(jié)構(gòu)。通常子樹被稱作“左子樹”和“右子樹”,左子...
    小貓仔閱讀 639評論 0 0
  • 參考兩篇其他bolg總結(jié)的二叉樹:https://github.com/xy7313/lintcode/blob/...
    暗黑破壞球嘿哈閱讀 2,513評論 0 1
  • 樹的概述 樹是一種非常常用的數(shù)據(jù)結(jié)構(gòu),樹與前面介紹的線性表,棧,隊列等線性結(jié)構(gòu)不同,樹是一種非線性結(jié)構(gòu) 1.樹的定...
    Jack921閱讀 4,762評論 1 31
  • 一. 二叉樹的定義 二叉樹(Binary Tree)是 n ( n >= 0) 個節(jié)點的有限集,這個集合可以為空,...
    NahuelK閱讀 2,108評論 0 1
  • 姓名: 李小娜 [嵌牛導讀] :這篇文章主要介紹了Java二叉排序樹,包括二叉排序樹的定義、二叉排序樹的性質(zhì)、二叉...
    n184閱讀 720評論 0 0

友情鏈接更多精彩內(nèi)容