PTA 玩轉二叉樹 25分

2021-10-09 10:07:05 字數 1198 閱讀 6811

給定一棵二叉樹的中序遍歷和前序遍歷,請你先將樹做個鏡面反轉,再輸出反轉後的層序遍歷的序列。所謂鏡面反轉,是指將所有非葉結點的左右孩子對換。這裡假設鍵值都是互不相等的正整數。

輸入第一行給出乙個正整數n(≤30),是二叉樹中結點的個數。第二行給出其中序遍歷序列。第三行給出其前序遍歷序列。數字間以空格分隔。

在一行中輸出該樹反轉後的層序遍歷的序列。數字間以1個空格分隔,行首尾不得有多餘空格。

7

1 2 3 4 5 6 7

4 1 3 2 6 5 7

4 6 1 7 5 3 2
#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include//int_max

//#include#define pp pair#define inf 0x3f3f3f3f

#define llinf 0x3f3f3f3f3f3f3f3fll

#define dinf 1000000000000.0

#define pi 3.1415926

typedef long long ll;

using namespace std;

int const mod=1e9+7;

const int maxn=1e4+10;

int n,zx[40],qx[40];

typedef struct nodekj,*tree;

void jtree(tree &t,int ks,int js,int cd)

else

return ;

}void fz(tree &t)

if(t->l!=null&&t->r!=null)

else if(t->l==null&&t->r!=null)

else if(t->l!=null&&t->r==null)

fz(t->l);

fz(t->r);

return;

}void cx(tree t)

}int main()

PTA玩轉二叉樹

7 26 玩轉二叉樹 25 分 給定一棵二叉樹的中序遍歷和前序遍歷,請你先將樹做個鏡面反轉,再輸出反轉後的層序遍歷的序列。所謂鏡面反轉,是指將所有非葉結點的左右孩子對換。這裡假設鍵值都是互不相等的正整數。輸入第一行給出乙個正整數n 30 是二叉樹中結點的個數。第二行給出其中序遍歷序列。第三行給出其前...

5 11 玩轉二叉樹 25分

給定一棵二叉樹的中序遍歷和前序遍歷,請你先將樹做個鏡面反轉,再輸出反轉後的層序遍歷的序列。所謂鏡面反轉,是指將所有非葉結點的左右孩子對換。這裡假設鍵值都是互不相等的正整數。輸入第一行給出乙個正整數n le 30 是二叉樹中結點的個數。第二行給出其中序遍歷序列。第三行給出其前序遍歷序列。數字間以空格分...

天梯 玩轉二叉樹 (25 分)

給定一棵二叉樹的中序遍歷和前序遍歷,請你先將樹做個鏡面反轉,再輸出反轉後的層序遍歷的序列。所謂鏡面反轉,是指將所有非葉結點的左右孩子對換。這裡假設鍵值都是互不相等的正整數。輸入第一行給出乙個正整數n 30 是二叉樹中結點的個數。第二行給出其中序遍歷序列。第三行給出其前序遍歷序列。數字間以空格分隔。在...