10 - 深度优先搜索BST
创始人
2025-05-28 13:13:36
0

深度优先搜索&BST

    • 1. 验证二叉搜索树
    • 2. 将有序数组转为二叉搜索树
    • 3. 有序链表转为二叉搜索树
    • 4. 将二叉搜索树变平衡

1. 验证二叉搜索树

这道题目比较容易陷入两个陷阱:

  • 不能单纯的比较左节点小于中间节点,右节点大于中间节点就完事了。
  • 样例中最小节点 可能是int的最小值,如果这样使用最小的int来比较也是不行的。
class Solution {
public:TreeNode* pre =nullptr;bool isValidBST(TreeNode* root) {if(root == nullptr) return true;bool left = isValidBST(root->left);if(!left || (pre != nullptr && pre->val >= root->val)) return false;pre = root;return isValidBST(root->right);}
};

2. 将有序数组转为二叉搜索树

给你一个整数数组 nums ,其中元素已经按升序排列,请你将其转换为一棵高度平衡二叉搜索树。

只要给我们一个有序数组,如果强调平衡,都可以以线性结构来构造二叉搜索树。

class Solution {
public:TreeNode* sortedArrayToBST(vector& nums,int l,int r){if(l > r) return nullptr;int m = (l + r) / 2;TreeNode* root = new TreeNode(nums[m]);root->left = sortedArrayToBST(nums,l,m - 1);root->right = sortedArrayToBST(nums,m + 1,r);return root;}TreeNode* sortedArrayToBST(vector& nums) {return sortedArrayToBST(nums,0,nums.size()-1);}
};

3. 有序链表转为二叉搜索树

给定一个单链表的头节点 head ,其中的元素 按升序排序 ,将其转换为高度平衡的二叉搜索树。

  • 方法一:转为有序数组来做
class Solution {
public:TreeNode* sortedListToBST(ListNode* head) {vector vec;while(head != nullptr){vec.push_back(head->val);head = head->next;}return sortedListToBST(vec, 0 , vec.size() - 1);}
private:TreeNode* sortedListToBST(vector& vec, int l, int r){if(l > r) return nullptr;int m = (l + r) / 2;TreeNode* root = new TreeNode(vec[m]);root->left = sortedListToBST(vec, l, m - 1);root->right = sortedListToBST(vec, m + 1, r);return root;}
};
  • 方法二:用快慢指针找中间节点
class Solution {
public:TreeNode* sortedListToBST(ListNode* head){return divide(head, nullptr);}
private:TreeNode* divide(ListNode* left, ListNode* right){if(left == right) return nullptr;ListNode* mid = getMid(left, right);TreeNode* root = new TreeNode(mid->val);root->left = divide(left, mid);root->right = divide(mid->next, right);return root;}ListNode* getMid(ListNode* left, ListNode* right){ListNode* slow = left;ListNode* fast = left;while(fast != right && fast->next != right){fast = fast->next->next;slow = slow->next;}return slow;}
};

4. 将二叉搜索树变平衡

给你一棵二叉搜索树,请你返回一棵平衡后的二叉搜索树,新生成的树应该与原来的树有着相同的节点值。如果有多种构造方法,请你返回任意一种。

中序遍历把二叉树转变为有序数组,然后在根据有序数组构造平衡二叉搜索树。

class Solution {
public:TreeNode* balanceBST(TreeNode* root) {traversal(root);return getTree(0, vec.size() - 1);}
private:vector vec;void traversal(TreeNode* root){if(root == nullptr) return;traversal(root->left);vec.push_back(root->val);traversal(root->right);}TreeNode* getTree(int l , int r){if(l > r) return nullptr;int m = (l + r) / 2;TreeNode* root = new TreeNode(vec[m]);root->left = getTree(l, m - 1);root->right = getTree(m + 1, r);return root;}
};

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...