LeetCode题目记录-654. 最大二叉树(C++代码实现)
2021/12/12 17:49:34
本文主要是介绍LeetCode题目记录-654. 最大二叉树(C++代码实现),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
题目链接:
https://leetcode-cn.com/problems/maximum-binary-tree/
题目要求:
C++代码实现:
/** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode *right; * TreeNode() : val(0), left(nullptr), right(nullptr) {} * TreeNode(int x) : val(x), left(nullptr), right(nullptr) {} * TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {} * }; */ class Solution { public: //digui TreeNode* digui(vector<int>& nums,int begin,int end){ if(begin > end){ return nullptr; } //得到当前范围内的最大值索引 int maxIndex = getCurrIndex(nums,begin,end); //构造根节点 TreeNode* root = new TreeNode(nums[maxIndex]); root->left = digui(nums,begin,maxIndex - 1); root->right = digui(nums,maxIndex + 1,end); return root; } //得到最大索引值的方法 int getCurrIndex(vector<int>& nums,int begin,int end){ int maxIndex = INT_MIN; int maxNum = INT_MIN; for(int i = begin;i <= end;i++){ if(nums[i] > maxNum){ maxIndex = i; maxNum = nums[i]; } } return maxIndex; } TreeNode* constructMaximumBinaryTree(vector<int>& nums) { int n = nums.size(); TreeNode* root = digui(nums,0,n - 1); return root; } };
AC截图
本题解仅作为个人复习查看使用,并无他用。
这篇关于LeetCode题目记录-654. 最大二叉树(C++代码实现)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23增量更新怎么做?-icode9专业技术文章分享
- 2024-11-23压缩包加密方案有哪些?-icode9专业技术文章分享
- 2024-11-23用shell怎么写一个开机时自动同步远程仓库的代码?-icode9专业技术文章分享
- 2024-11-23webman可以同步自己的仓库吗?-icode9专业技术文章分享
- 2024-11-23在 Webman 中怎么判断是否有某命令进程正在运行?-icode9专业技术文章分享
- 2024-11-23如何重置new Swiper?-icode9专业技术文章分享
- 2024-11-23oss直传有什么好处?-icode9专业技术文章分享
- 2024-11-23如何将oss直传封装成一个组件在其他页面调用时都可以使用?-icode9专业技术文章分享
- 2024-11-23怎么使用laravel 11在代码里获取路由列表?-icode9专业技术文章分享
- 2024-11-22怎么实现ansible playbook 备份代码中命名包含时间戳功能?-icode9专业技术文章分享