日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

【二叉树】先序序列为a,b,c,d 的不同二叉树的个数

發布時間:2025/4/16 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【二叉树】先序序列为a,b,c,d 的不同二叉树的个数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

【二叉樹】先序序列為a,b,c,d 的不同二叉樹的個數

rosefunR 2019-07-23 10:56:40 ?8639 ?收藏 17
分類專欄: LeetCode
版權
1.問題
先序序列(前序序列)為a,b,c,d 的不同二叉樹的個數是?

2.解決思路
已知,前序序列和中序序列可以唯一地確定一棵二叉樹。如果我們把前序序列看作為入棧次序,把中序序列看作為出棧次序,那么題意相當于“以序列 a,b,c,d 為入棧次序,則出棧序列的個數為?”

比如:

? ?a ? ? ? ? ? ?
?/ ? \
b ? ?d ? ? ? ??
?\ ? ??
? c ? ? ? ? ? ?
1
2
3
4
5
前序遍歷:(父左右)a bc d
中序遍歷:(左父右)bc a d

由前序遍歷,a 是父節點;那么,由中序遍歷, bc 就是左子樹; d是右子樹;
由前序遍歷,b是父節點;那么,由中序遍歷, c 就是右子樹;
得到的二叉樹是唯一的。

因此,這個二叉樹可以由以下的前序序列和中序序列確定:

前序序列,先壓入 ab; 壓出的 b 當做中序序列;再壓入 c, 再壓出 c, 再壓出 a ;再壓入 d, 再壓出 d .

卡特蘭數

一個棧(無窮大)的進棧序列為1,2,3,…,n,有多少個不同的出棧序列?

f ( n ) = C 2 n n ? C 2 n n ? 1 f(n) = C_{2n}^{n} - C_{2n}^{n-1}
f(n)=C?
2n
n
??? ?
??C?
2n
n?1
??? ?
?

如何單純按照先序序列來看的話,就是,把序列的每個點看作一個根節點,就相當于左子樹和右子樹可能個數兩部分相乘。

因此,本題的答案是 14。
————————————————
版權聲明:本文為CSDN博主「rosefunR」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/rosefun96/article/details/96974507

總結

以上是生活随笔為你收集整理的【二叉树】先序序列为a,b,c,d 的不同二叉树的个数的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。