二叉樹的查找(前序、中序、後序、層序遍歷)--biaobiao88

来源:https://www.cnblogs.com/biaobiao88/archive/2019/10/29/11761685.html
-Advertisement-
Play Games

建立一棵含有n個結點的二叉樹,採用二叉鏈表存儲; 輸出前序、中序、後序、、層序遍歷該二叉樹的遍歷結果。 定義二叉樹的數據類型——二叉樹結點結構體BiNode。建立二叉鏈表可以採用擴展二叉樹的一個遍歷序列,例如前序序列,將擴展二叉樹的前序序列由鍵盤輸入,建立該二叉樹的二叉鏈表存儲。 簡單起見,本實驗假 ...


建立一棵含有n個結點的二叉樹,採用二叉鏈表存儲;

輸出前序、中序、後序、、層序遍歷該二叉樹的遍歷結果。

定義二叉樹的數據類型——二叉樹結點結構體BiNode。建立二叉鏈表可以採用擴展二叉樹的一個遍歷序列,例如前序序列,將擴展二叉樹的前序序列由鍵盤輸入,建立該二叉樹的二叉鏈表存儲。

簡單起見,本實驗假定二叉樹的數據元素為char型

用模板類改寫

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<malloc.h>
int MaxSize = 100;
using namespace std;
typedef char DataType;
typedef struct BiNode
{
    DataType data;
    struct BiNode *lchile,*rchild;
}BiNode;
BiNode *root;

//創建拓展二叉樹,#代虛結點 
BiNode *Creat(BiNode *root)//          cishu   /////
{
    char ch;
    cin >> ch;
    if(ch == '#')
        root = NULL;
    else
    {
        root = (BiNode *)malloc(sizeof(BiNode));
        root->data = ch;
        root->lchile = Creat(root->lchile);
        root->rchild = Creat(root->rchild);
    }
    return root;
}

//前序遍歷 
void PreOrder(BiNode *root)
{
    if(root == NULL)
        return;
    else
    {
        cout << root->data << " ";
        PreOrder(root->lchile);
        PreOrder(root->rchild);
    }
}

//中序遍歷 
void InOrder(BiNode *root)
{
    if(root == NULL)
        return;
    else
    {
        InOrder(root->lchile);
        cout << root->data << " ";
        InOrder(root->rchild);
    }
}

//後序遍歷 
void PostOrder(BiNode *root)
{
    if(root == NULL)
        return;
    else
    {
        InOrder(root->lchile);
        InOrder(root->rchild);
        cout << root->data << " ";
    }
}

//層序遍歷 
void LevelOrder(BiNode *root)
{
    BiNode *q = NULL,*Q[MaxSize];
    int front = -1;
    int rear = -1;
    if(root == NULL)
        return;
    Q[++rear] = root;
    while(front != rear)
    {
        q = Q[++front];
        cout << q->data << " ";
        if(q->lchile != NULL)
            Q[++rear] = q->lchile;
        if(q->rchild != NULL)
            Q[++rear] = q->rchild;
    }
    
}

int main()
{
    BiNode *root = NULL;
    root = Creat(root);
    cout << "該二叉樹的根節點是:" << root->data << endl;
    cout << endl;
    cout << "該二叉樹的前序遍歷是:";
    PreOrder(root);
    cout << endl;
//    cout << "該二叉樹的根節點是:" << root->data << endl;
    cout << endl;
    cout << "該二叉樹的中序遍歷是:";
    InOrder(root);
    cout << endl;
//    cout << "該二叉樹的根節點是:" << root->data << endl;
    cout << endl;
    cout << "該二叉樹的後序遍歷是:";
    PostOrder(root);
    cout << endl;
//    cout << "該二叉樹的根節點是:" << root->data << endl;
    cout << endl;
    cout << "該二叉樹的層序遍歷是:";
    LevelOrder(root);
    cout << endl;
    return 0;
}

/*
abd##e##c#f##
該二叉樹的根節點是:a

該二叉樹的前序遍歷是:a b d e c f

該二叉樹的中序遍歷是:d b e a c f

該二叉樹的後序遍歷是:d b e c f a

該二叉樹的層序遍歷是:a b c d e f
*/

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1、首先創建一個抽象父類: 2、創建兩個列印類繼承抽象父類: 3、在創建一個properties配置文件,文件名為pro.properties 4、利用反射和多態調用列印類中的方法 測試得到結果 結論: 利用好java反射和多態機制,可以在不改變代碼的情況下,根據鍵值創建對應的類對象,通過多態方式執 ...
  • 今天進行了SSM框架的整合,遇到了很多的錯誤,但所幸都有解決,以下為基礎的整合步驟,後續待完善 1.SSM整合所需要: spring的jar(包含tx)、springmvc的jar、mybatis.jar、mybatis-spring.jar、tomcat、commons-dbcp.jar等 2.創 ...
  • __new__方法 創建實例的方法 __new__方法是在類創建實例的時候自動調用的 實例是通過類裡面的__new__方法創建出來的 先調用__new__方法創建實例,再調用 __init__方法初始化實例 __new__方法,後面括弧里的cls代表的是類本身 必須有返回值 父類名.__new__( ...
  • 我是一個不太愛折騰的人,因此在一個公司待久了,就不太會輕易跳槽。正因為如此,我在上家公司待了整整三年,在這裡,認識了一群可愛的人,便更不捨得離去。 但因為公司屬於傳統企業,技術上並沒有太大挑戰,個人也逐漸遇到了職業瓶頸,我也漸漸體會到了溫水煮青蛙的感覺,看似自己已經成為團隊的主程,其實與同齡人的差距 ...
  • 本文源碼: "GitHub·點這裡" || "GitEE·點這裡" 一、生活場景 1、場景描述 在電商高速發展的今天,快遞的數量十分龐大,甚至出現了快遞代理行業,簡單的說就是快遞的主人沒有時間收快遞,會指定一個快遞的代收點,比如快遞櫃,快遞驛站等,然後等有時間的時候再過去取,下麵使用代碼對這個場景進 ...
  • 一、全局變數 1. 定義在函數外面的變數是全局變數 2. 全局變數具有全局的生存期和作用域 3. 它們與任何函數無關,在任何函數內部都可以使用它們 二、全局變數初始化 1. 沒有做初始化的全局變數會得到0值 2. 指針會得到NULL值 3. 只能用編譯時刻已知的值來初始化全局變數 4. 它們的初始化 ...
  • 跟大家分享一下正式第一次使用 LaTex 的經驗,之前數學建模的時候一直想用,但沒有找到合適的軟體.前段時間,實驗室老師讓我幫忙套個 IEEE ACCESS 的模板. 嘗試過 TexPad,的確 UI 特別好看,奈何咋老報錯呢??? 然後乖乖回歸TexShop,用習慣了也不醜了. 因為老師給的文件是 ...
  • switch 是一個條件語句,用於將表達式的值與可能匹配的選項列表進行比較,並根據匹配情況執行相應的代碼塊。它可以被認為是替代多個 if else 子句的常用方式。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...