樹的同構(gòu)

給定兩顆二叉樹T1和T2,如果T1可以同過若干次左右孩子互換就變成T2,則我們稱為兩個樹是同構(gòu)的。現(xiàn)判斷兩棵樹是否同構(gòu)。

同構(gòu)與不同構(gòu)

【題目】

題意理解
第二棵樹

【靜態(tài)鏈表結(jié)構(gòu)數(shù)組表示二叉樹】

/* 靜態(tài)鏈表二叉樹 */
#define MaxTree 10
#define ElementType char
#define Tree int
#define Null -1

struct TreeNode
{
    ElementType Element;
    Tree Left;
    Tree Right;
}T1[MaxTree],T2[MaxTree];

/* 程序框架 */
int main()
{
    Tree R1,R2;

    R1=BuildTree(T1);
    R2=BuildTree(T2);
    if(Isomorphic(R1,R2))
        printf("Yes\n");
    else
        printf("No\n");

    return 0;
}

Tree BuildTree(struct TreeNode T[])
{
    scanf("%d\n",&N);
    if(N){
        for(i=0;i<N;i++) check[i]=0; //check為標志位
            for(i=0;i<N;i++){
                scanf("%c %c %c\n",&T[i].Element,&cl,&cr);
                if(cl!='-'){
                    /*check不為空,則說明存在子孩子
                        則將子孩子處的check置1,即存在被指向
                        在樹中check為0,即沒有被指向的節(jié)點就是root
                    */
                    T[i].Left=cl-'0';
                    check[T[i].Left]=1;
                }
                else
                    T[i].Left=NULL;

                if(cr!='-'){
                    T[i].Right=cl-'0';
                    check[T[i].Right]=1;
                }
                else
                    T[i].Right=NULL;
            }
            for(i=0;i<N;i++) //判別check值為0
                if(!check[i])   break;
            Root=i;
    }
    return Root;
}

int Isomorphic(Tree R1,Tree R2)
{
    if((R1==NULL)&&(R2==NULL))  
        return 1;
    if(((R1==NULL)&&(R2!=NULL))||((R1!=NULL)&&(R2==NULL)))
        return 0;
    if(T1[R1].Element!=T2[R2].Element)
        return 0;
    if((T1[R1].Left==NULL)&&(T2[R2].Left==NULL))
        return Isomorphic(T1[R1].Right,T1[R1].Right);
    if(((T1[R1].Left!=NULL)&&(T2[R2].Left!=NULL))&&
        ((T1[T1[R1].left].Element)==(T2[T2[R2].Left].Element)) )
        return (Isomorphic( T1[R1].Left, T2[R2].Left ) &&
            Isomorphic( T1[R1].Right, T2[R2].Right ) );
    else
        return ( Isomorphic( T1[R1].Left, T2[R2].Right) &&
            Isomorphic( T1[R1].Right, T2[R2].Left ) );
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,622評論 6 544
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,716評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,746評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,991評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,706評論 6 413
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 56,036評論 1 329
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,029評論 3 450
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 43,203評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,725評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 41,451評論 3 361
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,677評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,161評論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 44,857評論 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,266評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,606評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,407評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,643評論 2 380

推薦閱讀更多精彩內(nèi)容

  • 正文之前 在之前的【離散數(shù)學(xué)】圖論中談到過圖的同構(gòu),今天我們來談?wù)剺涞耐瑯?gòu): 同構(gòu)樹同構(gòu)有根樹同構(gòu)二叉樹 正文 同...
    胖若兩人_閱讀 14,763評論 1 6
  • 03-樹1 樹的同構(gòu) (25分)給定兩棵樹T1和T2。如果T1可以通過若干次左右孩子互換就變成T2,則我們稱兩...
    有苦向瓜訴說閱讀 316評論 0 0
  • 樹的概述 樹是一種非常常用的數(shù)據(jù)結(jié)構(gòu),樹與前面介紹的線性表,棧,隊列等線性結(jié)構(gòu)不同,樹是一種非線性結(jié)構(gòu) 1.樹的定...
    Jack921閱讀 4,475評論 1 31
  • 你笑著說 你的多篇文字里有我 那些庸常的點滴 在你筆尖一一細數(shù) 因你的文字里有我 我去讀你的詩歌 不經(jīng)意掀開一頁 ...
    之之坔閱讀 258評論 0 0
  • 輸出是最好的學(xué)習(xí),所以我把我所學(xué)所感收集整合分享出來,希望不僅能提高自己,也能給伙伴們帶來或多或少的收獲。 在當今...
    牛小丫53閱讀 1,030評論 10 37