日韩性视频-久久久蜜桃-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ò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 午夜在线播放 | 国产精品乱码一区二区视频 | 国产五十路 | 国产资源在线观看 | 最新国产精品自拍 | 日韩一区二区三区精品视频 | 91一二区| 91传媒理伦片在线观看 | 亚洲欧洲国产精品 | 欧美熟妇激情一区二区三区 | 在线cao | 在线视频网站 | 精品国产丝袜一区二区三区乱码 | 伊人日本 | 五月天在线播放 | 高h调教冰块play男男双性文 | 美女扒开屁股让男人桶 | 在线观看免费国产 | 日韩一区二区三区四区五区 | 国产精品久久综合 | 黑人玩弄人妻一区二区三区四 | 国产精品自产拍高潮在线观看 | 日韩视频一区二区三区在线播放免费观看 | 在线欧美日韩 | 69视频在线看| 色哟哟入口 | 国产精品电影一区二区三区 | 久久视频中文字幕 | 中文字幕黑丝 | 超碰97在线免费 | 色久在线 | 五月天色小说 | 色呦呦在线视频 | 欧美女优一区二区 | 亚洲精品综合 | 亚洲自拍偷拍色图 | 久久久久久成人精品 | 亚洲av少妇一区二区在线观看 | 91视频在线免费看 | 在线成人一区 | 99爱在线视频 | 成人在线免费高清视频 | 久久国产视频精品 | 亚洲图片欧美 | 就要干就要操 | 男人添女人下部高潮全视频 | 欧美日韩久久久久 | 自拍偷拍综合 | 国产精品视频福利 | 秋霞一区二区 | av丁香| 四虎影库| 日韩在线免费av | 牛牛影视av| 91爽爽 | av久色| 91色噜噜| 日本美女视频 | 国产美女精品久久 | 福利视频不卡 | 亚洲精品视频免费在线观看 | 国产福利精品视频 | 久久青草视频 | 精品久久福利 | 色吧在线视频 | 日本女人性视频 | 美女让男生桶 | 五月天激情视频在线观看 | 亚洲一区二区三区视频 | www.国产在线 | 欧洲一区在线 | 中文字幕亚洲欧美日韩 | 麻豆影视在线 | 超碰综合在线 | 国产69精品久久久久久久 | 69精品一区二区三区 | 亚洲自拍图片 | 欧美在线看片 | 成人免费在线视频 | 国产理论在线观看 | 久久久久久一级片 | 免费国产91| 深夜成人福利视频 | 久久伊人热 | 欧美成人久久久免费播放 | 亚洲女人网 | 人体内射精一区二区三区 | 蜜桃视频久久一区免费观看入口 | 日韩黄色短片 | 国产成人无码AA精品区 | 黄色小视频入口 | 亚洲国产成人精品91久久久 | 鲍鱼av在线 | 亚洲欧美综合一区二区 | 香蕉在线视频观看 | 欧美zzz物交| 岛国精品在线播放 | 污污内射在线观看一区二区少妇 | 人妻换人妻a片爽麻豆 |