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

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

将字符串转换为数组_LeetCode 树 108.将有序数组转换为二叉搜索树

發(fā)布時(shí)間:2024/1/23 编程问答 28 豆豆
生活随笔 收集整理的這篇文章主要介紹了 将字符串转换为数组_LeetCode 树 108.将有序数组转换为二叉搜索树 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

7(108) 將有序數(shù)組轉(zhuǎn)換為二叉搜索樹(shù)

描述

將一個(gè)按照升序排列的有序數(shù)組,轉(zhuǎn)換為一棵高度平衡二叉搜索樹(shù)。

本題中,一個(gè)高度平衡二叉樹(shù)是指一個(gè)二叉樹(shù)每個(gè)節(jié)點(diǎn) 的左右兩個(gè)子樹(shù)的高度差的絕對(duì)值不超過(guò) 1。

示例

給定有序數(shù)組: [-10,-3,0,5,9],一個(gè)可能的答案是:[0,-3,9,-10,null,5],它可以表示下面這個(gè)高度平衡二叉搜索樹(shù):0/ -3 9/ /-10 5

Description

Given an array where elements are sorted in ascending order, convert it to a height balanced BST.

For this problem, a height-balanced binary tree is defined as a binary tree in which the depth of the two subtrees of every node never differ by more than 1.

Example

Given the sorted array: [-10,-3,0,5,9],One possible answer is: [0,-3,9,-10,null,5], which represents the following height balanced BST:0/ -3 9/ /-10 5

BitDance Amazon Microsoft Adobe Apple Google Tencent Mi HuaWei VMware

解題

二叉搜索樹(shù) BST(Binary Search Tree) 又稱為二叉查找樹(shù) 二叉排序樹(shù) 二叉搜索樹(shù)或者是一棵空的樹(shù) 或者是具有以下特征的樹(shù): 1. 若左子樹(shù)非空 則左子樹(shù)上所有的結(jié)點(diǎn)key_val均小于根節(jié)點(diǎn)的key_val 2. 若右子樹(shù)非空 則右子樹(shù)上所有的結(jié)點(diǎn)key_val均大于根節(jié)點(diǎn)的key_val 3. 左右子樹(shù)本身也是二叉搜索樹(shù)

因此 對(duì)二叉搜索樹(shù)進(jìn)行中序遍歷 得到的一定是一個(gè)遞增的有序序列

#include <iostream>// SortedArray to BST #include <vector> #include <queue> using namespace std; struct TreeNode{int val;TreeNode *left;TreeNode *right;TreeNode(int x):val(x),left(NULL),right(NULL) {} }; TreeNode* levelCreateBinaryTree(const vector<int> &nums,int len,int index){//層序創(chuàng)建二叉樹(shù)index為位置序號(hào)TreeNode *root=NULL;if(index<len&&nums[index]!=-1){root = new TreeNode(nums[index]);root->left = levelCreateBinaryTree(nums,len,2*index+1);root->right= levelCreateBinaryTree(nums,len,2*index+2);}return root; } void PrintMartrix(vector<vector<int>>& res){//打印二維數(shù)組for(int i=0;i<res.size();++i){cout<<"[";for(int j=0;j<res[i].size();++j){cout<<" "<<res[i][j]<<" ";}cout<<"]"<<endl;} } class Solution { public:vector<vector<int>> levelOrder(TreeNode* root) {vector<vector<int>> res;if(!root) return res;queue<TreeNode* > Tree;Tree.push(root);while(!Tree.empty()){vector<int> temp;int len=Tree.size();while(len--){TreeNode *pNode=Tree.front();Tree.pop();temp.push_back(pNode->val);if(pNode->left) Tree.push(pNode->left);if(pNode->right) Tree.push(pNode->right);}res.push_back(temp);}return res;}vector<int> res;vector<int> inorderTraversal(TreeNode* root) {//遞歸算法if(root!=NULL){inorderTraversal(root->left);res.push_back(root->val);inorderTraversal(root->right);}return res;}TreeNode* sortedArrayToBST(vector<int>& nums) {if(nums.size()==0) return NULL;if(nums.size()==1) return new TreeNode(nums[0]);int mid=nums.size()/2;TreeNode* node=new TreeNode(nums[mid]);vector<int>::const_iterator first;vector<int>::const_iterator last;first=nums.begin();last=nums.begin()+mid;vector<int> v_temp(first,last);node->left=sortedArrayToBST(v_temp);if(mid==nums.size()-1) node->right=NULL;else{first=nums.begin()+mid+1;last=nums.end();vector<int> v_temp(first,last);node->right=sortedArrayToBST(v_temp);}return node;} }; int main(){vector<int> nums={0,1,2,3,4,5};//示例 值為-1代表所在位置為空值int len=nums.size();Solution answer;TreeNode *root=answer.sortedArrayToBST(nums);vector<vector<int>> res=answer.levelOrder(root);PrintMartrix(res);//打印層序遍歷的二維數(shù)組vector<int> print=answer.inorderTraversal(root);for(auto x:print) cout<<x<<" ";//打印中序遍歷的序列return 0; }

總結(jié)

以上是生活随笔為你收集整理的将字符串转换为数组_LeetCode 树 108.将有序数组转换为二叉搜索树的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 黄视频免费在线看 | 日本xxxx高清 | 国产精品无码专区av在线播放 | 能看毛片的网站 | 亚洲AV无码乱码国产精品色欲 | 99精品区 | 免费人成年激情视频在线观看 | 波多野结衣电影在线播放 | 免费黄色一级视频 | 久久久精品91 | 色老大视频 | 日韩动漫av | 二十四小时在线更新观看 | 中文av在线播放 | 秋霞电影网一区二区 | 欧美性一级 | 黄网站色视频 | 日韩专区一区 | 天天视频污| 97精品人妻一区二区三区在线 | 日本理论片中文字幕 | 老汉av在线| 网站毛片 | 阿v天堂2017| 在线观看中文字幕码 | 国产精品色视频 | 五月天爱爱 | 午夜影视av | 啪啪天堂 | 一区二区三区日韩视频 | a天堂资源在线 | 精品国产乱码久久久久久图片 | 免费伊人网 | 亚洲女人18毛片水真多 | 在线电影一区二区 | 午夜精品一区二区三区三上悠亚 | 人人澡超碰碰97碰碰碰 | 天天干天天谢 | 亚洲熟女乱综合一区二区三区 | 日韩国产欧美一区二区 | 美女毛毛片 | 狠狠躁日日躁夜夜躁 | www.成人网| 日韩精品在线一区二区 | 丰满av| 久久久夜 | 亚洲一区二区三区四区在线 | 青春草久久 | 久久夜色精品国产噜噜亚洲av | 青青草免费在线视频 | 日韩首页 | 青青草一区二区 | 日韩欧美理论 | 大片av| 少妇被躁爽到高潮 | 大奶一区 | 激情自拍偷拍 | 亚洲 欧美 变态 另类 综合 | 成人性生活免费视频 | 999久久久 | 亚洲国产精品久久久久 | 一区在线观看 | 成人午夜在线免费观看 | avtt在线观看| 亚洲成人免费 | 玖玖久久 | 欧美日韩国产一区二区 | 欧美性极品xxxx做受 | 男男上床视频 | 做暧暧视频在线观看 | 中日韩午夜理伦电影免费 | 高清成人| 人妻少妇精品视频一区二区三区 | 亚洲精品国产精品乱码视色 | 91在线国产观看 | 91麻豆精品国产91久久久无需广告 | 欧美人与性禽动交精品 | 欧美影视一区二区 | 亚洲综合图片区 | 国产精品xxx在线观看www | 日韩人妻无码精品综合区 | 久久福利在线 | 韩国av不卡 | 欧美hdse| 超碰美女 | 男女扒开双腿猛进入爽爽免费 | 91亚洲精品国偷拍自产在线观看 | 日韩二区三区四区 | 一级片大片| 免费成人av片 | xiuxiuavnet| 摸大乳喷奶水www视频 | 国产日韩欧美视频在线观看 | 嫩草www | 丰满少妇一区二区三区 | 人物动物互动39集免费观看 | 少妇精品导航 | 在线观看911视频 | 我不卡一区二区 |