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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

二叉树经典题之根据二叉树创建字符串(二叉树的括号表示法)

發布時間:2025/3/15 编程问答 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 二叉树经典题之根据二叉树创建字符串(二叉树的括号表示法) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

前言:

二叉樹刷題是有固定思維的,請移步

README】二叉樹刷題框架

根據二叉樹創建字符串

題目

點擊跳轉:LeetCode

遞歸解法

這道題其實考察到的是二叉樹的括號表示法,括號表示法依靠括號的劃分來區分左子樹和右子樹。整體思路不難,也即使遞歸創建:首先字符串中加入結點的值,然后遍歷左子樹和右子樹,在遍歷每棵子樹的時候首先創建(,然后遞歸,接著遞歸完成之后再創建),對于空結點則表示為()

也就是如果不要去管題目的其它限制,可以寫出這種情況下遞歸代碼

class Solution { public:string tree2str(TreeNode* root) {string ret;if(root=nullptr)return ret;ret+=to_string(root-val);ret+='(';//遍歷子樹先加左括號ret+=tree2str(root->left);//遞歸ret+=')';//遍歷完成之后再加右括號ret+='(';ret+=tree2str(root->right);ret+=')';} };

這樣創建出的字符串是不滿足題意的,題目要求的是對于可以省略的括號應該省略。比如下圖中結點3由于沒有左右子樹,所以它的空結點就不創建括號,還有結點2它只有左子樹沒有右子樹,但是右子樹寫不寫括號不影響對應,因此可以不寫它右子樹的括號

但是有些括號不能省略,比如下圖中,結點2沒有左子樹但是擁有右子樹,如果此時省略了結點2的左子樹的括號,那么在括號表示法中就無法區分4到底是左子樹還是右子樹了
所以綜上我們可以寫出如下代碼

class Solution { public:string tree2str(TreeNode* root) {string ret;if(root==nullptr){return ret;}ret+=to_string(root->val);if(root->left==nullptr && root->right==nullptr){return ret;}ret+='(';ret+=tree2str(root->left);ret+=')';if(root->right!=nullptr){ret+='(';ret+=tree2str(root->right);ret+=')';}return ret;} };

如果不滿足 if(root->left==nullptr && root->right==nullptr),指的就是就是此時 root->left==nullptr 但是root->right!=nulltptr,這種情況下正好就符合我們的邏輯,左子樹遞歸進去創建括號,右子樹進入if判斷也創建括號,以此就正確區分了左右子樹

優化

從剛才代碼的提交結構中大家可以看到,時間以及空間效率都及其低下,其實這也是遞歸的通病,遞歸的思路很簡單。我們在上面的代碼中使用的是string,string用的不好會導致大量的深拷貝,因此會嚴重影響效率。
解決方法就是新建一個沒有返回值的遞歸函數_tree2str,在主函數中建立一個string,通過引用傳參即可

class Solution { public:void _tree2str(TreeNode* root,string& ret){if(root==nullptr)return;ret+=to_string(root->val);if(root->left==nullptr && root->right==nullptr)return;ret+='(';_tree2str(root->left,ret);ret+=')';if(root->right!=nullptr){ret+='(';_tree2str(root->right,ret);ret+=')';} }string tree2str(TreeNode* root) {string ret;_tree2str(root,ret);return ret;} };

可以發現,這樣寫代碼的效率得到了很大的提高

總結

以上是生活随笔為你收集整理的二叉树经典题之根据二叉树创建字符串(二叉树的括号表示法)的全部內容,希望文章能夠幫你解決所遇到的問題。

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