第10周 專案3 計算二叉樹節點個數

2021-07-24 09:37:24 字數 1390 閱讀 4824

問題及描述:

1.標頭檔案:btree.h,包含定義順序表資料結構的**、巨集定義、要實現演算法的函式的宣告;

#define maxsize 100  

typedef char elemtype;

typedef struct node

btnode;

void createbtnode(btnode *&b,char *str); //由str串建立二叉鏈

btnode *findnode(btnode *b,elemtype x); //返回data域為x的節點指標

btnode *lchildnode(btnode *p); //返回*p節點的左孩子節點指標

btnode *rchildnode(btnode *p); //返回*p節點的右孩子節點指標

int btnodedepth(btnode *b); //求二叉樹b的深度

void dispbtnode(btnode *b); //以括號表示法輸出二叉樹

void destroybtnode(btnode *&b); //銷毀二叉樹

2.原始檔:btree.cpp,包含實現各種演算法的函式的定義

#include #include #include "btree.h"  

void createbtnode(btnode *&b,char *str) //由str串建立二叉鏈

} }

j++;

ch=str[j];

} } btnode *findnode(btnode *b,elemtype x) //返回data域為x的節點指標

} btnode *lchildnode(btnode *p) //返回*p節點的左孩子節點指標

btnode *rchildnode(btnode *p) //返回*p節點的右孩子節點指標

int btnodedepth(btnode *b) //求二叉樹b的深度

} void dispbtnode(btnode *b) //以括號表示法輸出二叉樹

} } void destroybtnode(btnode *&b) //銷毀二叉樹

}

3.計算二叉樹節點個數;

#include #include "btree.h"  

int nodes(btnode *b)

int main()

執行結果:

第10周 專案3 (1)計算二叉樹節點個數

1.標頭檔案 btree.h,包含定義順序表資料結構的 巨集定義 要實現演算法的函式的宣告 define maxsize 100 typedef char elemtype typedef struct node btnode void createbtnode btnode b,char str ...

第十周專案3 計算二叉樹節點個數

檔名稱 二叉樹.cpp 完成日期 2015年11月18日 版本號 vc 6.0 問題描述 二叉樹解決問題 輸入描述 無 程式輸出 二叉樹節點數 ifndef btree h included define btree h included define maxsize 100 typedef cha...

完全二叉樹節點個數

關於作者 最簡單的解法就是遍歷這棵樹,時間複雜度是o n 如果只是這一種解法,就不會有本文了。本文中給出兩種解法。第一次看到完全二叉樹的定義比較懵,搜尋到的定義如下 設二叉樹的深度為h,除第 h 層外,其它各層 1 h 1 的結點數都達到最大個數,第h層所有的結點都連續集中在最左邊,這就是完全二叉樹...