青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

從上節(jié)的討論得知:遍歷二杈樹是以一定規(guī)則將二杈樹中結(jié)點(diǎn)排列成一個線性序列,得到二杈樹中結(jié)點(diǎn)的先序序列或中序序列或后序序列。這實(shí)際上是對一個非線性結(jié)構(gòu)進(jìn)行線性化操作,使每個結(jié)點(diǎn)(除第一個和最后一個外)在這些線性序列中有且僅有一個直接前驅(qū)和直接后繼。但是,當(dāng)以二杈鏈表作為存儲結(jié)構(gòu)時(shí),只能找到結(jié)點(diǎn)的左,右孩子的信息,而不能直接得到結(jié)點(diǎn)在任一序列中的前驅(qū)和后繼信息,這種信息只能在遍歷的動態(tài)過程中才能得到。
????? 因?yàn)樵谟衝個結(jié)點(diǎn)的二杈鏈表中必定存在n+1個空鏈域,故可以利用這些空鏈域來存放結(jié)點(diǎn)的前驅(qū)和后繼信息。
????? 試做如下規(guī)定:若結(jié)點(diǎn)有左子樹,則其lchild域指示其左孩子,否則令lchild域指示其前驅(qū);若結(jié)點(diǎn)有右子樹,則其rchild域指示其右孩子,否則令rchild域指示其后繼。為了避免混淆,需要改變結(jié)點(diǎn)結(jié)構(gòu),增加兩個標(biāo)志域:LTag,RTag。
????? 其中:LTag = 0,lchild域指示其左孩子;? LTag = 1,lchild域指示其前驅(qū)。
??????????? RTag = 0,rchild域指示其右孩子;? RTag = 1,rchild域指示其后繼。
????? 以這種結(jié)點(diǎn)結(jié)構(gòu)構(gòu)成的二杈鏈表作為二杈樹的存儲結(jié)構(gòu),叫做線索鏈表,其中指向結(jié)點(diǎn)前驅(qū)和后繼的指針,叫做線索。加上線索的二杈樹叫做線索二杈樹。對二杈樹以某種次序遍歷使其變成線索二杈樹的過程叫做線索化。
????? 在線索樹上進(jìn)行遍歷,只要先找到序列中的第一個結(jié)點(diǎn),然后依次找結(jié)點(diǎn)后繼直到其后繼為空為止。
????? 求遍歷后的線性序列的前驅(qū)和后繼。前序線索化能依次找到后繼,但是前驅(qū)需要求雙親;中序線索化前驅(qū)和后繼都不需要求雙親,但是都不很直接;后序線索化能依次找到前驅(qū),但是后繼需要求雙親。可以看出,線索化成中序是最佳的選擇,基本上算是達(dá)到了要求。
????? //二杈樹的二杈線索存儲表示
typedef enum PointerTag {Link, Thread}; //Link:指針,Thread:線索
typedef struct BiThrNode{
????? ElemType data;
????? struct BiThrNode *lchild, *rchild;//左,右孩子指針
????? PointerTag LTag, RTag; //左,右標(biāo)志
} *BiThrTree;
????? 為了方便起見,我們仿照線性表的存儲結(jié)構(gòu),在二杈樹的線索鏈表上也添加一個頭結(jié)點(diǎn),并令其lchild域的指針指向二杈樹的根結(jié)點(diǎn),其rchild域的指針指向中序遍歷時(shí)訪問的最后一個結(jié)點(diǎn);反之,令二杈樹中序序列的第一個結(jié)點(diǎn)的lchild域的指針和最后一個結(jié)點(diǎn)的rchild域的指針均指向頭結(jié)點(diǎn)。這好比為二杈樹建立了一個雙向線索鏈表,既可以從第一個結(jié)點(diǎn)起順后繼進(jìn)行遍歷,也可以從最后一個結(jié)點(diǎn)起順前驅(qū)進(jìn)行遍歷。
?void InOrderTraverse_Thr(BiThrTree T)//中序遍歷線索二杈樹的非遞歸算法, T 指向頭結(jié)點(diǎn)
{
????? BiThrTree p = T->lchild; //p指向根結(jié)點(diǎn)

????? while (p != T) //空樹或遍歷結(jié)束時(shí),p == T
????? {
??????????? while (p->LTag == Link)//尋找第一個結(jié)點(diǎn)
??????????? {
????????????????? p = p->lchild;
??????????? }
??????????? cout << p->data << ' ';//輸出該結(jié)點(diǎn)

??????????? while (p->RTag == Thread && p->rchild != T)//訪問后繼結(jié)點(diǎn)
??????????? {
????????????????? p = p->rchild;
????????????????? cout << p->data << ' ';//輸出該結(jié)點(diǎn)
??????????? }

??????????? p = p->rchild;
????? }
}

void InThreading(BiThrTree & p, BiThrTree & pre) //中序線索化
{
????? if (p)
????? {
??????????? InThreading(p->lchild, pre); //左子樹線索化
??????????? if (! p->lchild)//若當(dāng)前結(jié)點(diǎn)的左子樹為空,則建立前驅(qū)線索
??????????? {
????????????????? p->LTag = Thread;
????????????????? p->lchild = pre;
??????????? }
??????????? else
????????????????? p->LTag = Link;
??????????? if (pre && !pre->rchild)//若前驅(qū)結(jié)點(diǎn)非空,且其右孩子為空,則建立后繼線索
??????????? {
????????????????? pre->RTag = Thread;
????????????????? pre->rchild = p;
??????????? }
??????????? pre = p;??? //中序向前遍歷接點(diǎn) ,保持pre指向p的前驅(qū)
??????????? pre->RTag = Link;//默認(rèn)前驅(qū)結(jié)點(diǎn)右孩子非空
??????????? InThreading(p->rchild, pre); //右子樹線索化
????? }
}

BiThrTree InOrderThreading(BiThrTree T)//中序遍歷二杈樹,并將其中序線索化
{
????? BiThrTree Thrt = new BiThrNode;? //建立頭結(jié)點(diǎn)
????? if (!Thrt)
?{
??printf("Out of space!");
??return NULL;
?}
?Thrt->LTag = Link;
?Thrt->RTag = Thread;
?Thrt->rchild = Thrt; //右指針回指

?if (!T)//若二杈樹為空,則左指針回指
??????????? Thrt->lchild = Thrt;
????? else
????? {
??????????? Thrt->lchild = T;
??????????? BiThrTree pre = Thrt;
??????????? InThreading(T, pre);//中序線索化

??????????? pre->rchild = Thrt; //最后一個結(jié)點(diǎn)線索化
??????????? pre->RTag = Thread;
??????????? Thrt->rchild = pre; //此時(shí)pre指向最后一個結(jié)點(diǎn)
????? }
????? return Thrt;
}

////////////////////////////////////////////////////////////////////////////////////////
//應(yīng)用示例:我先生成一棵二杈排序樹(輸入單個字符,以#結(jié)束),并以遞歸方式遍歷輸出結(jié)點(diǎn);
//然后把該二杈排序樹中序線索化,最后中序遍歷線索二杈樹輸出結(jié)點(diǎn)。
#include <iostream>

using namespace std;

//二杈樹的二杈線索存儲表示
typedef char ElemType;
typedef enum PointerTag {Link, Thread}; //Link:指針,Thread:線索
typedef struct BiThrNode{
????? ElemType data;
????? struct BiThrNode *lchild, *rchild;//左,右孩子指針
????? PointerTag LTag, RTag; //左,右標(biāo)志
} *BiThrTree;

void InOrderTraverse_Thr(BiThrTree T);//中序遍歷線索二杈樹的非遞歸算法, T 指向頭結(jié)點(diǎn)
void InThreading(BiThrTree & p, BiThrTree & pre); //中序線索化
BiThrTree InOrderThreading(BiThrTree T);//中序遍歷二杈樹,并將其中序線索化
void CreateBTree(BiThrTree & bt);//生成一棵二杈排序樹(輸入單個字符,以#結(jié)束)
BiThrTree NewBTree(ElemType x);//構(gòu)造一個數(shù)據(jù)域?yàn)閤的新結(jié)點(diǎn)
void Insert(BiThrTree & b, BiThrTree s);//在二杈排序樹中插入新結(jié)點(diǎn)s
void InOrderPrint_1(BiThrTree p); //中序遍歷輸出結(jié)點(diǎn)(遞歸)

int main()
{
????? BiThrTree bt = NULL;

????? CreateBTree(bt);//生成一棵二杈排序樹(輸入單個字符,以#結(jié)束)
????? InOrderPrint_1(bt); //中序遍歷輸出結(jié)點(diǎn)(遞歸)
????? cout << endl;

????? BiThrTree BT = InOrderThreading(bt);//中序遍歷二杈樹,并將其中序線索化
????? InOrderTraverse_Thr(BT);//中序遍歷線索二杈樹的非遞歸算法, T 指向頭結(jié)點(diǎn)

????? system("PAUSE");
????? return EXIT_SUCCESS;
}

void InOrderTraverse_Thr(BiThrTree T)//中序遍歷線索二杈樹的非遞歸算法, T 指向頭結(jié)點(diǎn)
{
????? BiThrTree p = T->lchild; //p指向根結(jié)點(diǎn)

????? while (p != T) //空樹或遍歷結(jié)束時(shí),p == T
????? {
??????????? while (p->LTag == Link)//尋找第一個結(jié)點(diǎn)
??????????? {
????????????????? p = p->lchild;
??????????? }
??????????? cout << p->data << ' ';//輸出該結(jié)點(diǎn)

??????????? while (p->RTag == Thread && p->rchild != T)//訪問后繼結(jié)點(diǎn)
??????????? {
????????????????? p = p->rchild;
????????????????? cout << p->data << ' ';//輸出該結(jié)點(diǎn)
??????????? }

??????????? p = p->rchild;
????? }
}

void InThreading(BiThrTree & p, BiThrTree & pre) //中序線索化
{
????? if (p)
????? {
??????????? InThreading(p->lchild, pre); //左子樹線索化
??????????? if (! p->lchild)//若當(dāng)前結(jié)點(diǎn)的左子樹為空,則建立前驅(qū)線索
??????????? {
????????????????? p->LTag = Thread;
????????????????? p->lchild = pre;
??????????? }
??????????? else
????????????????? p->LTag = Link;
??????????? if (pre && !pre->rchild)//若前驅(qū)結(jié)點(diǎn)非空,且其右孩子為空,則建立后繼線索
??????????? {
????????????????? pre->RTag = Thread;
????????????????? pre->rchild = p;
??????????? }
??????????? pre = p;??? //中序向前遍歷接點(diǎn) ,保持pre指向p的前驅(qū)
??????????? pre->RTag = Link;//默認(rèn)前驅(qū)結(jié)點(diǎn)右孩子非空
??????????? InThreading(p->rchild, pre); //右子樹線索化
????? }
}

BiThrTree InOrderThreading(BiThrTree T)//中序遍歷二杈樹,并將其中序線索化
{
????? BiThrTree Thrt = new BiThrNode;? //建立頭結(jié)點(diǎn)
????? if (!Thrt)
?{
??printf("Out of space!");
??return NULL;
?}
?Thrt->LTag = Link;
?Thrt->RTag = Thread;
?Thrt->rchild = Thrt; //右指針回指

?if (!T)//若二杈樹為空,則左指針回指
??????????? Thrt->lchild = Thrt;
????? else
????? {
??????????? Thrt->lchild = T;
??????????? BiThrTree pre = Thrt;
??????????? InThreading(T, pre);//中序線索化

??????????? pre->rchild = Thrt; //最后一個結(jié)點(diǎn)線索化
??????????? pre->RTag = Thread;
??????????? Thrt->rchild = pre; //此時(shí)pre指向最后一個結(jié)點(diǎn)
????? }
????? return Thrt;
}

void CreateBTree(BiThrTree & bt)//生成一棵二杈排序樹(輸入單個字符,以#結(jié)束)
{
????? ElemType x;
????? cin >> x;
????? while (x != '#')
????? {
??????????? BiThrTree s = NewBTree(x);//構(gòu)造一個數(shù)據(jù)域?yàn)閤的新結(jié)點(diǎn)
??????????? Insert(bt, s);//在二杈排序樹中插入新結(jié)點(diǎn)s
??????????? cin >> x;
????? }
}

BiThrTree NewBTree(ElemType x)//構(gòu)造一個數(shù)據(jù)域?yàn)閤的新結(jié)點(diǎn)
{
?BiThrTree s = new BiThrNode;
????? if (!s)
?{
??printf("Out of space!");
??exit (1);
?}
?s->data = x;
?s->lchild = s->rchild = NULL;
?s->LTag = s->RTag = Link;

????? return s;
}


void Insert(BiThrTree & b, BiThrTree s)//在二杈排序樹中插入新結(jié)點(diǎn)s
{
?if (b == NULL)
??b = s;
?else if (b->data == s->data)//不做任何插入操作
??return;
?else if(b->data > s->data)//把s所指結(jié)點(diǎn)插入到左子樹中
????? Insert(b->lchild, s);
?else?????????????? //把s所指結(jié)點(diǎn)插入到右子樹中
????? Insert(b->rchild, s);
}

void InOrderPrint_1(BiThrTree p) //中序遍歷輸出結(jié)點(diǎn)(遞歸)
{
?if (p != NULL)
?{
??InOrderPrint_1(p->lchild); //遍歷左子樹
??????????? cout << p->data << ' ';//輸出該結(jié)點(diǎn)
??InOrderPrint_1(p->rchild); //遍歷右子樹
?}
}

Posted on 2006-05-18 16:13 夢想飛揚(yáng) 閱讀(1530) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲视频免费看| 欧美精品 国产精品| 欧美成人国产va精品日本一级| 亚洲天堂免费观看| 亚洲男女毛片无遮挡| 欧美在线视频a| 老牛影视一区二区三区| 欧美激情导航| 一区二区三区国产精华| 亚洲一区二区3| 久久精品成人欧美大片古装| 久久一区国产| 欧美午夜免费影院| 国产日产精品一区二区三区四区的观看方式 | 99国产精品久久久久老师 | 在线观看视频亚洲| 亚洲精品乱码久久久久久| 亚洲夜间福利| 牛人盗摄一区二区三区视频| 亚洲国产婷婷| 亚洲一区二区四区| 另类尿喷潮videofree| 国产精品海角社区在线观看| 激情综合色丁香一区二区| 一区二区欧美日韩| 欧美一区亚洲二区| 老司机精品福利视频| 免费毛片一区二区三区久久久| 亚洲高清视频的网址| 亚洲性夜色噜噜噜7777| 老牛嫩草一区二区三区日本| 国产精品丝袜久久久久久app| 亚洲欧洲美洲综合色网| 久久国产一二区| 日韩一级裸体免费视频| 理论片一区二区在线| 国产手机视频精品| 亚洲欧美日韩国产中文| 亚洲激情视频在线播放| 久久久欧美一区二区| 国产精品卡一卡二| 99精品国产在热久久| 嫩草国产精品入口| 欧美一区二区三区电影在线观看| 欧美日韩精品一区二区| 亚洲国内在线| 欧美www视频| 久久国产精品99久久久久久老狼 | 1769国内精品视频在线播放| 性做久久久久久久免费看| aa成人免费视频| 欧美日本一区二区高清播放视频| 亚洲精品韩国| 亚洲人成人一区二区三区| 免费黄网站欧美| 亚洲激情在线观看视频免费| 免费在线欧美黄色| 久久另类ts人妖一区二区| 国内伊人久久久久久网站视频| 欧美在线视频日韩| 欧美在线视频一区| 尤物视频一区二区| 欧美激情片在线观看| 欧美精品久久久久久久免费观看 | 欧美国产第一页| 久久一区精品| 91久久精品视频| 亚洲精品少妇30p| 欧美三级视频| 欧美专区在线播放| 久久久久久电影| 91久久精品日日躁夜夜躁欧美| 欧美国产日韩精品免费观看| 美乳少妇欧美精品| 一区二区三区精品国产| 一区二区免费看| 国产毛片精品国产一区二区三区| 久久成人精品视频| 亚洲精选成人| 久久精品人人做人人爽| 欧美色网在线| 午夜精品福利视频| 国产欧美日韩另类视频免费观看| 欧美/亚洲一区| 亚洲麻豆国产自偷在线| 免费在线欧美视频| 亚洲高清中文字幕| 亚洲精品资源美女情侣酒店| 欧美国产日本在线| 亚洲影院污污.| 欧美91大片| 在线一区视频| 国产一区二区三区久久久久久久久| 欧美在线观看一区二区| 久久久欧美一区二区| 最新69国产成人精品视频免费| 欧美激情一区二区三区全黄 | 尤物精品在线| 欧美11—12娇小xxxx| 一本色道久久加勒比88综合| 午夜欧美精品| 亚洲免费成人av电影| 欧美日韩中文字幕日韩欧美| 欧美在线播放高清精品| 亚洲国产日韩欧美一区二区三区| 亚洲欧美另类综合偷拍| 亚洲经典在线看| 国产一区美女| 国产精品视频你懂的| 欧美精品一线| 欧美成人精品| 毛片基地黄久久久久久天堂| 欧美一区二区黄色| 午夜精品久久久久久99热| 欧美一区二区免费| 国产精品久久久久久av福利软件| 久久亚洲私人国产精品va媚药| 99re66热这里只有精品4| 亚洲国产第一页| 最新日韩精品| 亚洲一区三区电影在线观看| 亚洲一区二区三区中文字幕| 亚洲国产高清在线| 一区在线视频| 亚洲国产精品久久久久婷婷老年| 国产精品亚洲片夜色在线| 国产精品一区免费观看| 国产精品一级| 伊人夜夜躁av伊人久久| 亚洲国产精品电影| 一本色道久久综合亚洲精品不| 一本大道久久精品懂色aⅴ| 亚洲一级影院| 久久婷婷久久一区二区三区| 老色鬼精品视频在线观看播放| 欧美成人tv| 一区二区三区黄色| 久久国产精品久久久| 亚洲专区在线视频| 久久精品日韩| 亚洲国产欧美国产综合一区| 亚洲乱码精品一二三四区日韩在线| 亚洲一区亚洲| 欧美精品久久99久久在免费线| 国产精品久久9| 99国产精品国产精品久久 | 久久午夜av| 午夜一区二区三视频在线观看| 美女图片一区二区| 亚洲欧美视频在线| 国产精品久久久久久久久久久久久久| 亚洲电影在线看| 午夜精品美女自拍福到在线| 老司机免费视频久久| 亚洲一本大道在线| 欧美日韩中文字幕综合视频| 亚洲精品一区二区在线| 欧美大成色www永久网站婷| 久久gogo国模裸体人体| 国产在线视频欧美一区二区三区| 欧美一站二站| 欧美在线观看你懂的| 精品成人在线| 日韩视频永久免费观看| 国产精品成人播放| 久久久久国产精品午夜一区| 欧美一区2区视频在线观看| 国产自产2019最新不卡| 亚洲电影激情视频网站| 欧美国产在线电影| 这里只有精品视频| 性欧美精品高清| 日韩一级片网址| 久久免费午夜影院| 欧美阿v一级看视频| 午夜精品视频在线观看| 久久夜色精品国产欧美乱极品| 亚洲色图在线视频| 久久伊伊香蕉| 欧美在线观看www| 欧美激情免费在线| 蜜桃av综合| 国产欧美日韩不卡| 亚洲精品一级| 亚洲国产精品久久久久秋霞蜜臀| 一本色道久久| 亚洲午夜精品| 国产精品va在线播放| 久久婷婷麻豆| 一区二区三区成人| 亚洲国产成人久久| 久久久久久久激情视频| 久久久久久电影| 国产亚洲网站| 久久精品一区蜜桃臀影院| 久久久久网站| 亚洲国产一区在线观看| 久久野战av| 欧美xxx成人| 日韩一级精品视频在线观看|