第10周 專案1 二叉樹演算法庫

2021-07-06 08:42:37 字數 2914 閱讀 6427

問題描述及**:

#ifndef btree_h_included

#define btree_h_included

/*

*煙台大學計控學院

*作 者:楊徵

*完成日期:2023年11月2日

*問題描述:定義二叉樹的鏈式儲存結構,實現其基本運算,並完成測試。

要求:

1、標頭檔案btree.h中定義資料結構並宣告用於完成基本運算的函式。對應基本運算的函式包括:

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); //銷毀二叉樹1

2、在btree.cpp中實現這些函式

3、在main函式中完成測試,包括如下內容:

(1)用」a(b(d,e(h(j,k(l,m(,n))))),c(f,g(,i)))」建立如圖的二叉樹用於測試。

(2)輸出二叉樹

(3)查詢值為』h』的節點,若找到,輸出值為』h』的節點的左、右孩子的值

(4)求高度二叉樹高度

(5)銷毀二叉樹

*/#endif // btree_h_included

(1)btree.h

#ifndef btree_h_included

#define btree_h_included

#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); //銷毀二叉樹

#endif // btree_h_included

(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)main.cpp

#include"btree.h"

#includeint main()

else

printf(" 未找到!");

printf("\n");

printf(" (4)二叉樹b的深度:%d\n",btnodedepth(b));

printf(" (5)釋放二叉樹b\n");

destroybtnode(b);

return 0;

}

執行結果:

知識點總結:

二叉樹的基本運算:

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); //銷毀二叉樹1

學習心得:

感覺二叉樹這邊有點繞,可能是因為用了遞迴演算法

第10周 專案1 二叉樹演算法庫

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

第10周專案1 二叉樹演算法庫

問題及 檔名稱 cpp1.cpp 完成日期 2015年11月02日 版本號 v1.0 問題描述 定義二叉樹的鏈式儲存結構,實現其基本運算,並完成測試。標頭檔案 btree.h,包含定義順序表資料結構的 巨集定義 要實現演算法的函式的宣告 ifndef btree h included define ...

第10周 專案1 二叉樹演算法庫

問題及 檔名稱 test.cpp 作 者 焦夢真 完成日期 2015年11月2日 版 本 號 v1.0 問題描述 定義二叉樹的鏈式儲存結構,實現其基本運算,並完成測試。輸入描述 程式輸出 include include btree.h int main else printf 未找到!printf ...