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

首頁 > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)之二叉樹四:還原二叉樹

2019-11-11 02:07:07
字體:
供稿:網(wǎng)友

sdut原題鏈接

數(shù)據(jù)結(jié)構(gòu)實(shí)驗(yàn)之二叉樹四:還原二叉樹 Time Limit: 1000MS Memory Limit: 65536KB

PRoblem Description 給定一棵二叉樹的先序遍歷序列和中序遍歷序列,要求計(jì)算該二叉樹的高度。

Input 輸入數(shù)據(jù)有多組,每組數(shù)據(jù)第一行輸入1個(gè)正整數(shù)N(1 <= N <= 50)為樹中結(jié)點(diǎn)總數(shù),隨后2行先后給出先序和中序遍歷序列,均是長度為N的不包含重復(fù)英文字母(區(qū)分大小寫)的字符串。

Output 輸出一個(gè)整數(shù),即該二叉樹的高度。

Example Input 9 ABDFGHIEC FDHGIBEAC

Example Output 5

Hint

Author xam

以下為accepted代碼

#include <stdio.h>#include <string.h>#include <stdlib.h>typedef struct node{ char date; struct node *left; struct node *right;}BinTree;BinTree *root;int len;char st1[54], st2[54];BinTree * ans(int len, char *st1, char *st2)//建立二叉樹函數(shù){ if(len == 0) return NULL; int i; BinTree *root; root = (BinTree *)malloc(sizeof(BinTree)); root->date = st1[0];//尋找根節(jié)點(diǎn),新的根節(jié)點(diǎn)為st1的第一個(gè) for(i = 0; i < len; i++)//尋找新的根節(jié)點(diǎn)在中序序列st2中的位置 { if(st2[i] == root->date) break; } root->left = ans(i, st1+1, st2);//(左子樹的長度,左子樹在st1中的開始位置,左子樹在st2中的開始位置) root->right = ans(len-i-1, st1+i+1, st2+i+1);//(右子樹的長度,右子樹在st1中的開始位置,右子樹在st2中的開始位置) return root;}int get_hight(BinTree *root)//計(jì)算二叉樹的深度函數(shù){ int HL, HR, MAXH; if(root) { HL = get_hight(root->left); HR = get_hight(root->right); MAXH = HL>HR? HL: HR; return (MAXH + 1); } else return 0;}int main(){ int n, y; while(scanf("%d", &n) != EOF) { scanf("%s %s", st1, st2); root = ans(n, st1, st2);//調(diào)用建立二叉樹函數(shù) y = get_hight(root);//調(diào)用計(jì)算二叉樹的深度函數(shù) printf("%d/n", y); } return 0;}/***************************************************User name: jk160630Result: AcceptedTake time: 0msTake Memory: 116KBSubmit time: 2017-02-07 19:21:23****************************************************/
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 涞源县| 二连浩特市| 本溪| 镇巴县| 射洪县| 杭锦旗| 龙岩市| 沁水县| 花莲市| 元朗区| 晴隆县| 固镇县| 东明县| 吉木萨尔县| 临高县| 出国| 常德市| 灌阳县| 房产| 涞水县| 鄂伦春自治旗| 梅州市| 双桥区| 达尔| 天峨县| 吴江市| 恭城| 阳西县| 康马县| 邛崃市| 厦门市| 车致| 余庆县| 右玉县| 社旗县| 长治县| 海口市| 瑞昌市| 册亨县| 那坡县| 新余市|