C++基于遞歸和非遞歸算法判定兩個二叉樹結(jié)構(gòu)是否完全相同(結(jié)構(gòu)和數(shù)據(jù)都相同)
本文實(shí)例講述了C++基于遞歸和非遞歸算法判定兩個二叉樹結(jié)構(gòu)是否完全相同。分享給大家供大家參考,具體如下:
/*兩個二叉樹結(jié)構(gòu)是否相同(結(jié)構(gòu)和數(shù)據(jù)都相同) -- 遞歸和非遞歸方法 經(jīng)調(diào)試可運(yùn)行源碼及分析如下: ***/ #include <stdlib.h> #include <iostream> #include <queue> using std::cout; using std::cin; using std::endl; using std::queue; /*二叉樹結(jié)點(diǎn)定義*/ typedef struct BTreeNode { char elem; struct BTreeNode *pleft; struct BTreeNode *pright; }BTreeNode; /*初始化二叉樹節(jié)點(diǎn)*/ BTreeNode* btree_init(BTreeNode* &bt) { bt = NULL; return bt; } /*先序創(chuàng)建二叉樹*/ void pre_crt_tree(BTreeNode* &bt) { char ch; cin >> ch; if (ch == '#') { bt = NULL; } else { bt = new BTreeNode; bt->elem = ch; pre_crt_tree(bt->pleft); pre_crt_tree(bt->pright); } } /* 遞歸方式: 如果兩個二叉樹proot都為空樹,則自然相同,返回true; 如果兩個二叉樹proot一個為空樹,另一個不為空樹,則不相同,返回false; 如果兩個二叉樹的數(shù)據(jù)不相等,返回false; 如果兩個二叉樹都不為空樹,則需要分別比較左右子樹后,根據(jù)比較結(jié)果共同判定,只要有一個為false,則返回false。 */ /*遞歸判斷兩個二叉樹是否相等(結(jié)構(gòu)和數(shù)據(jù))*/ bool bitree_compare(BTreeNode* proot1, BTreeNode* proot2) { if (proot1 == NULL && proot2 == NULL)//都為空 return true; if((proot1 != NULL && proot2 == NULL) || (proot1 == NULL && proot2 != NULL))//一個空,一個非空 return false; /*比較元素*/ if(proot1->elem != proot2->elem) return false; bool left_compare = bitree_compare(proot1->pleft, proot2->pleft); bool right_compare = bitree_compare(proot1->pright, proot2->pright); return (left_compare && right_compare); } /* 非遞歸方式 借助隊列實(shí)現(xiàn) 實(shí)現(xiàn)算法: 首先將給定根節(jié)點(diǎn)proot1和proot2都入隊 第一步:當(dāng)兩個隊列未空時,分別獲取兩個樹的當(dāng)前層次中節(jié)點(diǎn)總數(shù)(即當(dāng)前隊列中節(jié)點(diǎn)個數(shù)), 先比較節(jié)點(diǎn)個數(shù)是否相同,如果不相同,則兩個樹自然不同; 如果節(jié)點(diǎn)個數(shù)相同,需要出隊進(jìn)行比較(數(shù)據(jù)也要比較)。如果有一個隊列未空,則退出比較。 第二步:如果有一個隊列未空,則清空隊列并返回不同。 */ /*非遞歸方式判斷兩個二叉樹是否相等(僅僅結(jié)構(gòu))*/ bool bitree_compare_leveltraverse(BTreeNode* proot1, BTreeNode* proot2) { if (proot1 == NULL && proot2 == NULL)//都為空 return true; queue <BTreeNode*> que1; queue <BTreeNode*> que2; que1.push(proot1); que2.push(proot2); int cur_level_nodes_num1 = 0; int cur_level_nodes_num2 = 0; bool flag = true; while (!que1.empty() && !que2.empty()) { cur_level_nodes_num1 = que1.size(); cur_level_nodes_num2 = que2.size(); //節(jié)點(diǎn)數(shù)目不一樣時flag設(shè)為false,退出循環(huán) if (cur_level_nodes_num1 != cur_level_nodes_num2) { flag = false; break; } int cur_level_node_count1 = 0; int cur_level_node_count2 = 0; while (cur_level_node_count1 < cur_level_nodes_num1 && cur_level_node_count2 < cur_level_nodes_num2) { ++cur_level_node_count1; ++cur_level_node_count2; proot1 = que1.front(); que1.pop(); proot2 = que2.front(); que2.pop(); /*元素數(shù)據(jù)比較*/ if(proot1->elem != proot2->elem) { flag = false; break; } //判斷左右孩子是否相同,不同肯定結(jié)構(gòu)不相同,提前break if( proot1->pleft == NULL && proot2->pleft != NULL || proot1->pleft != NULL && proot2->pleft == NULL || proot1->pright == NULL && proot2->pright != NULL || proot1->pright != NULL && proot2->pright == NULL) { flag = false; break; } /*下一層的節(jié)點(diǎn)入隊*/ if(proot1->pleft) que1.push(proot1->pleft); if(proot1->pright) que1.push(proot1->pright); if(proot2->pleft) que2.push(proot2->pleft); if(proot2->pright) que2.push(proot2->pright); } if(flag == false) break; } if(flag == false) { while(!que1.empty()) que1.pop(); while(!que2.empty()) que2.pop(); cout << "非遞歸:reslut is false." << endl; return false; }else { cout << "非遞歸:reslut is true." << endl; return true; } return true; } int main() { BTreeNode *bt1; BTreeNode* bt2; bool flag; btree_init(bt1);//初始化根節(jié)點(diǎn) btree_init(bt2);//初始化根節(jié)點(diǎn) cout << "creat 1th tree:" << endl; pre_crt_tree(bt1);//創(chuàng)建二叉樹 cout << "creat 2th tree:" << endl; pre_crt_tree(bt2);//創(chuàng)建二叉樹 /*遞歸測試*/ flag = bitree_compare(bt1, bt2); if(flag == true) cout<< "遞歸:result is true." << endl; else cout << "遞歸:result is false." << endl; /*非遞歸測試*/ bitree_compare_leveltraverse(bt1, bt2); system("pause"); return 0; }
/* 測試結(jié)果如下: creat 1th tree: a b c # # # d e # # f # g # # creat 2th tree: a b c # # # d e # # f # g # # 遞歸:result is true. 非遞歸:reslut is true. 請按任意鍵繼續(xù). . . ------------------分界線----------------------- creat 1th tree: a b c # # # d # # creat 2th tree: a b c # # # x # # 遞歸:result is false. 非遞歸:reslut is false. 請按任意鍵繼續(xù). . . 本例創(chuàng)建的二叉樹形狀: a b c # # # d e # # f # g # # 如下: a b d c e f g a b c # # # d # # 如下: a b d c a b c # # # x # # 如下: a b x c */
希望本文所述對大家C++程序設(shè)計有所幫助。
上一篇:C++ 中 const和static readonly區(qū)別
欄 目:C語言
下一篇:用C語言模仿Python函數(shù)的實(shí)例
本文標(biāo)題:C++基于遞歸和非遞歸算法判定兩個二叉樹結(jié)構(gòu)是否完全相同(結(jié)構(gòu)和數(shù)據(jù)都相同)
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/1578.html
您可能感興趣的文章
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求階乘
- 01-10深入理解C++中常見的關(guān)鍵字含義
- 01-10使用C++實(shí)現(xiàn)全排列算法的方法詳解
- 01-10c++中inline的用法分析
- 01-10深入理解二叉樹的非遞歸遍歷
- 01-10用C++實(shí)現(xiàn)DBSCAN聚類算法
- 01-10全排列算法的非遞歸實(shí)現(xiàn)與遞歸實(shí)現(xiàn)的方法(C++)
- 01-10C++大數(shù)模板(推薦)
- 01-10淺談C/C++中的static與extern關(guān)鍵字的使用詳解


閱讀排行
本欄相關(guān)
- 04-02c語言函數(shù)調(diào)用后清空內(nèi)存 c語言調(diào)用
- 04-02func函數(shù)+在C語言 func函數(shù)在c語言中
- 04-02c語言的正則匹配函數(shù) c語言正則表達(dá)
- 04-02c語言用函數(shù)寫分段 用c語言表示分段
- 04-02c語言中對數(shù)函數(shù)的表達(dá)式 c語言中對
- 04-02c語言編寫函數(shù)冒泡排序 c語言冒泡排
- 04-02c語言沒有round函數(shù) round c語言
- 04-02c語言分段函數(shù)怎么求 用c語言求分段
- 04-02C語言中怎么打出三角函數(shù) c語言中怎
- 04-02c語言調(diào)用函數(shù)求fibo C語言調(diào)用函數(shù)求
隨機(jī)閱讀
- 01-10delphi制作wav文件的方法
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 01-10C#中split用法實(shí)例總結(jié)
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 04-02jquery與jsp,用jquery
- 01-11ajax實(shí)現(xiàn)頁面的局部加載