国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > C > 正文

遞歸刪除二叉樹中以x為根的子樹

2020-01-26 13:30:49
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

名稱:刪除二叉樹中以x為根的子樹

說(shuō)明:此程序的大部分內(nèi)容,注釋都解釋的較為詳細(xì)了。在這里需要提及一點(diǎn)的是此處遞歸函數(shù)flag傳遞的不是上篇中講的引用,而是普通的變量,因?yàn)樵谙蛳聜鬟f參數(shù)(當(dāng)前結(jié)點(diǎn)是否是x的信息)的過(guò)程中只要傳遞給對(duì)應(yīng)的子樹,并不需要傳遞給整個(gè)樹的結(jié)點(diǎn)。在下一篇會(huì)做個(gè)關(guān)于遞歸傳遞參數(shù)的總結(jié)。

//遞歸刪除二叉樹中以x為根的子樹,(flag為標(biāo)志)int DelRoot_x(BiTree &T, int x,int flag){  if(T == NULL)    return 0;  else  {    if(T->data == x)  //如果當(dāng)前節(jié)點(diǎn)的值為x,則更改標(biāo)志位,在下面將向遞歸子函數(shù)中傳遞flag值    {      flag = 1;    }    int lef_ret = DelRoot_x(T->lchild,x,flag); //遞歸左子樹,lef_ret為從左子樹中返回的信息    int rig_ret = DelRoot_x(T->rchild,x,flag); //遞歸右子樹,rig_ret為從右子樹中返回的信息    if(1 == flag)    //如果標(biāo)志為1,說(shuō)明其祖父結(jié)點(diǎn)中有x,也就是說(shuō)當(dāng)前結(jié)點(diǎn)需要?jiǎng)h除    {      if(T->data == x)  //如果是x結(jié)點(diǎn),則需要向上層結(jié)點(diǎn)傳遞信息,以便其父節(jié)點(diǎn)將對(duì)應(yīng)的指針域賦空        return 1;      delete T;    }    else    {       if(1 == lef_ret)  //從子結(jié)點(diǎn)接受收的信息,即如果其子結(jié)點(diǎn)為x,需要將其指針域賦空        T->lchild = NULL;      if(1 == rig_ret )  //從子結(jié)點(diǎn)接受收的信息,即如果其子結(jié)點(diǎn)為x,需要將其指針域賦空        T->rchild = NULL;    }  }  return 0;}

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)武林網(wǎng)的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 怀仁县| 庆云县| 张家港市| 吴江市| 内丘县| 新野县| 邯郸市| 涟水县| 蒙自县| 天柱县| 克拉玛依市| 兴宁市| 曲松县| 阳泉市| 灵山县| 盱眙县| 墨竹工卡县| 牟定县| 嘉定区| 西吉县| 兴城市| 大足县| 板桥市| 论坛| 烟台市| 新乡市| 兴国县| 卢龙县| 广灵县| 青海省| 宜宾县| 延津县| 乌苏市| 定西市| 舞钢市| 桐梓县| 新巴尔虎左旗| 兴安盟| 淮滨县| 山阳县| 克山县|