西西軟件下載最安全的下載網站、值得信賴的軟件下載站!

首頁編程開發(fā)其它知識 → 數(shù)據結構中二叉樹基本操作學習

數(shù)據結構中二叉樹基本操作學習

相關軟件相關文章發(fā)表評論 來源:西西整理時間:2013/1/30 8:42:10字體大。A-A+

作者:西西點擊:0次評論:0次標簽: 二叉樹

谷歌瀏覽器2016(Chrome)v50.0.2661.75 官方正式版
  • 類型:瀏覽器類大小:43.2M語言:中文 評分:6.0
  • 標簽:
立即下載

近日受人所托,搞了點二叉樹的程序,順便回顧了下二叉樹的一些基本知識,特此總結。

二叉樹的基本操作,可能包括:

創(chuàng)建,遍歷,轉化,復制,刪除等。

遍歷:前中后三種順序的遍歷,已經是各數(shù)據結構與算法教程的最基礎內容,在此不重復。

創(chuàng)建:大多數(shù)據結構教程當中的二叉樹創(chuàng)建程序,都是采用的遞歸方式,遞歸方式創(chuàng)建的二叉樹與遍歷的過程相似,所創(chuàng)建的二叉樹,也是采用左右子節(jié)點方式,后續(xù)進行遍歷操作十分方便。

轉化:直覺上,最簡單的二叉樹存儲方式其實是如下圖的數(shù)組:

*此圖出自某高校數(shù)據結構ppt,但實在難以查證是哪個學校,無法直接感謝,請諒解。

首先,提供個滿二叉樹大小的數(shù)組,然后其中數(shù)值按完全二叉樹存儲。顯然,此種順序存儲方法:第i號(這里編號指對應的完全二叉樹的位序)結點的左右孩子一定保存在第2i及2i+1號單元中。故此,為兼顧存儲的直觀與遍歷等操作的方便,從順序數(shù)組向左右子節(jié)點存儲方式的轉化也就十分重要。

1-轉化方法

分為幾個步驟:

(1)準備原始數(shù)組

(2)分析數(shù)組中的有效值,對應二叉樹節(jié)點非空;

(3)創(chuàng)建二叉樹節(jié)點;

(4)計算除最后一層子節(jié)點外,構造節(jié)點間父子關系時的循環(huán)次數(shù);

(5)構造二叉樹節(jié)點間的父子關系;

(6)確實二叉樹根節(jié)點;

主要代碼:

(1)準備原始數(shù)組

//原始數(shù)組
    int intBiTreeInit[ARR_COUNT];

   
    //初始化原始數(shù)組至無效值
    for(int i=0;i<=ARR_COUNT-1;i++)
 intBiTreeInit[i]=NVALUE;

    //本if條件確保ARR_COUNT是否是的乘方-1
    if(0==(ARR_COUNT & (ARR_COUNT+1)))
    {
 for(int i=0;i<=ARR_COUNT-1;i++)
     intBiTreeInit[i]=2*(i+1);
    }
    else
 return RET_ERR;

    //使最后兩數(shù)為無效值
    intBiTreeInit[ARR_COUNT-1]=NVALUE;
    intBiTreeInit[ARR_COUNT-2]=NVALUE;

(2)分析數(shù)組中的有效值

    //開始獲得數(shù)組中有效值位置
    int intRel=0;
    int intArr=0;
    for(intArr=0;intArr<=intCount-1;intArr++)
    {
 if(elemArr[intArr]!=elemNValue)
 {
     intRel++;
     vecIntEffPos.push_back(intArr);
 }
 }

(3)創(chuàng)建二叉樹節(jié)點

    //數(shù)組中有效值對應創(chuàng)建節(jié)點
    //同時初始化父子節(jié)點為NULL
    for(intArr=0;intArr<=intRel-1;intArr++)
    {
 pBiTreeTemp=(PBiTreeNode)malloc(sizeof(BiTreeNode));;
 
 if(NULL==pBiTreeTemp)    //判斷是否有足夠的內存空間
 {
     cout<<"Memory alloc failure"<<endl;
     return RET_ERR;
 }

 //將有效值賦予節(jié)點
 pBiTreeTemp->BiTreeData=elemArr[vecIntEffPos[intArr]];
 
 //初始化左右子節(jié)點為null,便于后續(xù)的遍歷
 pBiTreeTemp->leftChild=NULL;
 pBiTreeTemp->rightChild=NULL;

 //先存節(jié)點值
 vecPBiTree.push_back(pBiTreeTemp);
   }

(4)計算除最后一層子節(jié)點外,構造節(jié)點間父子關系時的循環(huán)次數(shù)

//生成父子關系時最后一層不必遍歷,故理論循環(huán)上限可優(yōu)化

    int intSubLast=0;
    intSubLast=intCount-(intCount+1)/2;

(5)構造二叉樹節(jié)點間的父子關系

    for(intArr=0;intArr<=intSubLast-1;intArr++)
    {
 //左右節(jié)點若存儲有效值則同時創(chuàng)建父子關系
 if(elemArr[intArr*2+1]!=elemNValue)
     vecPBiTree[intArr]->leftChild=vecPBiTree[intArr*2+1];
     
 if(elemArr[intArr*2+2]!=elemNValue)
     vecPBiTree[intArr]->rightChild=vecPBiTree[intArr*2+2];
  }

(6)確實二叉樹根節(jié)點

pBiTree=vecPBiTree[0];

轉化為左右子節(jié)點方式存儲后,則各種遍歷操作按大多數(shù)教程的常規(guī)方式處理即可,如前序遍歷函數(shù):

int BiTreePreTrace(PBiTreeNode &pBiTree)
{
    //條件為非空樹
    if(pBiTree)
    {
 cout<<"Node value="<<(pBiTree->BiTreeData)<<endl;
 
 BiTreePreTrace(pBiTree->leftChild);    //遍歷左子樹
 BiTreePreTrace(pBiTree->rightChild);    //遍歷右子樹
    }
    return RET_OK;
}

完整程序,請見附件文件

*上述程序在Windows7x64,vs2008環(huán)境編譯運行通過。

    火狐瀏覽器
    (34)火狐瀏覽器
    火狐瀏覽器安卓版功能特性快速快速瀏覽從啟動到頁面加載,到平移和縮放,都有超快的瀏覽體驗智能工具欄輕點智能工具欄,即可獲得經常訪問的網站列表,書簽和歷史記錄,點擊訪問,無需輸入便捷簡潔易用標簽頁便于您同時瀏覽多個站點加載項提供無圖閱讀模式,流量受限時啟用也能便捷查看網頁智能同步從任何裝置存取您瀏覽器的歷史紀錄,書簽,密碼,以及開啟的標簽頁閱讀自動將零散的文章組合成美觀易讀的頁面插件提供多種功能插件以豐富您的瀏...更多>>
    ie瀏覽器
    (39)ie瀏覽器
    西西軟件園提供好用的瀏覽器官方下載,包括,瀏覽器真的是越來越強大了,界面極其清爽簡潔新增網頁固定功能智能網址地址欄快速訪問入口獨立標簽頁下載管理器開發(fā)人員工具多功能地址欄加載管理和跟蹤保護功能支持和加速功能。...更多>>
    • ie11 64位 for win7官方正式版

      01-29 / 87.2M

      推薦理由:ie11 win7 64位官方正式版適用于win7 64位的系統(tǒng)。微軟為IE11添加了一些新特性,比如對WebGL的支持,以及對
    • ie瀏覽器(Internet Explorer 11)v1

      01-29 / 28.1M

      推薦理由:微軟Internet Explorer 11今天正式發(fā)布,Windows 7以上版本均可以安裝,而Windows 8.1系統(tǒng)則內置了這一版本
    • IE10 64位版win7 X64官方正式版(IE

      02-26 / 41.7M

      推薦理由:微軟已經正式發(fā)布nternet Explorer 10 for Windows 7,這一版本讓Windows 7用戶等待了好久。之前IE10一直僅
    • IE10(Internet Explorer 10 for Wi

      11-16 / 21.7M

      推薦理由:微軟已經正式發(fā)布nternet Explorer 10 for Windows 7,這一版本讓Windows 7用戶等待了好久。之前IE10一直僅
    • IE10預覽版官方第四版

      02-15 / 19.5M

      推薦理由:IE10平臺預覽版第四版(PP4),使得IE瀏覽器的靈活性得到進一步增強。新版IE10在HTML5技術上帶來了相當大的
    • IE7 for xp /2003V7.0.5730.13官方

      10-30 / 13.7M

      推薦理由:IE7中文版支持中文域名,包含了許多重大安全改進的Internet Explorer 7終于發(fā)布了最新正式版本。微軟通過其
    opera瀏覽器
    (34)opera瀏覽器
    目前市場上的安卓瀏覽器種類繁多,不過有一款瀏覽器卻一直活躍在安卓系統(tǒng)上,那就是歐朋瀏覽器。歐朋瀏覽器是全球最流行的手機瀏覽器的中文版本。歐朋手機瀏覽器基于開發(fā),延續(xù)小巧快速節(jié)省流量的優(yōu)點,同時集成了諸多貼近中國用戶的社會化應用。歐朋瀏覽器最大的特色就是快,與同類產品相比優(yōu)勢比較明顯。體積小,適應性好,同時支持智能非智能手機。歐朋瀏覽器特點歐朋瀏覽器支持智能預讀智能縮放手勢操作,外加時尚個性化的界面...更多>>
    瀏覽器2016
    (24)瀏覽器2016
    西西軟件園強力推薦的瀏覽器下載排行榜產品,目前市場上的瀏覽器產品眾多,大家可能會有選擇性困難,到底哪款瀏覽器速度最快,體驗最好最安全這些都是在使用瀏覽器當中常見的疑問,如何選擇一款最好的瀏覽器,其實最適合的就是最好的。火狐瀏覽器是一個完全開放源代碼,任何人都可以自由參與開發(fā)的,支持多種操作系統(tǒng)的瀏覽器,因為其強大的可定制性和豐富的擴展程序而成為最有個性的瀏覽器.和支持最好,彈窗攔截和更勝一籌,執(zhí)行速度...更多>>
    搜狗瀏覽器
    (68)搜狗瀏覽器
    搜狗瀏覽器是搜狗公司推出的國內首款集高速的內核谷歌瀏覽器內核與兼容的內核微軟瀏覽器內核于一身的雙核高速瀏覽器。最新推出的搜狗高速瀏覽器.正式版具有具有超高速,超兼容,超安全的特點。搜狗瀏覽器還具有擴展功能,涵蓋了從工作學習生活服務系統(tǒng)工具時尚休閑資訊閱讀到影音視頻游戲娛樂大類余款擴展。更有包括登錄助手如意淘微信搖一搖傳圖等特色擴展。搜狗助手搜狗助手是一款用于訂購火車票的助手軟件,能夠減少大家在網上訂...更多>>

    相關評論

    閱讀本文后您有什么感想? 已有人給出評價!

    • 8 喜歡喜歡
    • 3 頂
    • 1 難過難過
    • 5 囧
    • 3 圍觀圍觀
    • 2 無聊無聊

    熱門評論

    最新評論

    發(fā)表評論 查看所有評論(0)

    昵稱:
    表情: 高興 可 汗 我不要 害羞 好 下下下 送花 屎 親親
    字數(shù): 0/500 (您的評論需要經過審核才能顯示)
    推薦文章

    沒有數(shù)據