当前位置: 首页 > news >正文

凡科手机建站教程中国国家人事人才培训网

凡科手机建站教程,中国国家人事人才培训网,网站打开乱码,交友网站去哪里做文章目录 一、题目二、解法三、完整代码 所有的LeetCode题解索引&#xff0c;可以看这篇文章——【算法和数据结构】LeetCode题解。 一、题目 二、解法 思路分析&#xff1a;注意不要落入下面你的陷阱&#xff0c;笔者本来想左节点键值<中间节点键值<右节点键值即可&…

文章目录

  • 一、题目
  • 二、解法
  • 三、完整代码

所有的LeetCode题解索引,可以看这篇文章——【算法和数据结构】LeetCode题解。

一、题目

在这里插入图片描述
在这里插入图片描述

二、解法

  思路分析:注意不要落入下面你的陷阱,笔者本来想左节点键值<中间节点键值<右节点键值即可,写出如下代码:

class Solution2 {
public:// 1、输入参数, 返回值为result,以引用方式传入void traversal_preOrder(TreeNode* cur, bool &result) {// 2、终止条件if (cur == NULL) return;if (cur->left && cur->left->val >= cur->val) result = 0;if (cur->right && cur->right->val <= cur->val) result = 0;// 3、单层递归逻辑if (result) traversal_preOrder(cur->left, result);     // 左if (result) traversal_preOrder(cur->right, result);    // 右}bool isValidBST(TreeNode* root) {bool result = 1;traversal_preOrder(root, result);return result;}
};

  在leetcode执行时遇到下面的错误,再次读题,发现是所有左子树的键值小于中间节点键值,所有右子树键值大于中间节点键值,这个性质和中序遍历有所关联。如此一来,我们就想到用中序遍历来做,中序遍历数组是一个有序数组,判断该数组是否有序即可
在这里插入图片描述

  程序如下

class Solution {
public:void traversal_midOrder(TreeNode* cur, vector<int>& vec) {if (cur == NULL) return;traversal_midOrder(cur->left, vec);     // 左vec.push_back(cur->val);                // 中traversal_midOrder(cur->right, vec);    // 右}bool isValidBST(TreeNode* root) {if (root == NULL) return {};vector<int> v;traversal_midOrder(root, v);for (int i = 0; i < v.size()-1; i++) {if (v[i] >= v[i + 1]) return false;}return true;}
};

三、完整代码

# include <iostream>
# include <vector>
# include <string>
# include <queue>
using namespace std;// 树节点定义
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:void traversal_midOrder(TreeNode* cur, vector<int>& vec) {if (cur == NULL) return;traversal_midOrder(cur->left, vec);     // 左vec.push_back(cur->val);                // 中traversal_midOrder(cur->right, vec);    // 右}bool isValidBST(TreeNode* root) {if (root == NULL) return {};vector<int> v;traversal_midOrder(root, v);for (int i = 0; i < v.size()-1; i++) {if (v[i] >= v[i + 1]) return false;}return true;}
};class Solution2 {
public:// 1、输入参数, 返回值为result,以引用方式传入void traversal_preOrder(TreeNode* cur, bool &result) {// 2、终止条件if (cur == NULL) return;if (cur->left && cur->left->val >= cur->val) result = 0;if (cur->right && cur->right->val <= cur->val) result = 0;// 3、单层递归逻辑if (result) traversal_preOrder(cur->left, result);     // 左if (result) traversal_preOrder(cur->right, result);    // 右}bool isValidBST(TreeNode* root) {bool result = 1;traversal_preOrder(root, result);return result;}
};// 前序遍历迭代法创建二叉树,每次迭代将容器首元素弹出(弹出代码还可以再优化)
void Tree_Generator(vector<string>& t, TreeNode*& node) {if (!t.size() || t[0] == "NULL") return;    // 退出条件else {node = new TreeNode(stoi(t[0].c_str()));    // 中if (t.size()) {t.assign(t.begin() + 1, t.end());Tree_Generator(t, node->left);              // 左}if (t.size()) {t.assign(t.begin() + 1, t.end());Tree_Generator(t, node->right);             // 右}}
}template<typename T>
void my_print(T& v, const string msg)
{cout << msg << endl;for (class T::iterator it = v.begin(); it != v.end(); it++) {cout << *it << ' ';}cout << endl;
}template<class T1, class T2>
void my_print2(T1& v, const string str) {cout << str << endl;for (class T1::iterator vit = v.begin(); vit < v.end(); ++vit) {for (class T2::iterator it = (*vit).begin(); it < (*vit).end(); ++it) {cout << *it << ' ';}cout << endl;}
}// 层序遍历
vector<vector<int>> levelOrder(TreeNode* root) {queue<TreeNode*> que;if (root != NULL) que.push(root);vector<vector<int>> result;while (!que.empty()) {int size = que.size();  // size必须固定, que.size()是不断变化的vector<int> vec;for (int i = 0; i < size; ++i) {TreeNode* node = que.front();que.pop();vec.push_back(node->val);if (node->left) que.push(node->left);if (node->right) que.push(node->right);}result.push_back(vec);}return result;
}int main()
{vector<string> t = { "5", "4", "NULL", "NULL", "6", "3", "NULL", "NULL", "7", "NULL", "NULL" };   // 前序遍历my_print(t, "目标树");TreeNode* root = new TreeNode();Tree_Generator(t, root);vector<vector<int>> tree = levelOrder(root);my_print2<vector<vector<int>>, vector<int>>(tree, "目标树:");Solution s;bool result = s.isValidBST(root);if (result) cout << "是一棵二叉搜索树" << endl;else cout << "不是一棵二叉搜索树" << endl;system("pause");return 0;
}

end


文章转载自:
http://mint.fcxt.cn
http://autocollimation.fcxt.cn
http://monosyllabism.fcxt.cn
http://soapy.fcxt.cn
http://subbasement.fcxt.cn
http://emolument.fcxt.cn
http://dcs.fcxt.cn
http://walrus.fcxt.cn
http://oblomovism.fcxt.cn
http://parthenogenone.fcxt.cn
http://readopt.fcxt.cn
http://planaria.fcxt.cn
http://oarweed.fcxt.cn
http://carbamidine.fcxt.cn
http://fingerful.fcxt.cn
http://skandalon.fcxt.cn
http://tonsure.fcxt.cn
http://strobilation.fcxt.cn
http://algolagnia.fcxt.cn
http://hughie.fcxt.cn
http://anarthrous.fcxt.cn
http://tbm.fcxt.cn
http://unitar.fcxt.cn
http://fodder.fcxt.cn
http://contain.fcxt.cn
http://acrophony.fcxt.cn
http://heterosexuality.fcxt.cn
http://orphan.fcxt.cn
http://mythos.fcxt.cn
http://chaos.fcxt.cn
http://cotransduction.fcxt.cn
http://gullable.fcxt.cn
http://elkhound.fcxt.cn
http://trump.fcxt.cn
http://prematurely.fcxt.cn
http://timeless.fcxt.cn
http://succulently.fcxt.cn
http://teachware.fcxt.cn
http://probatory.fcxt.cn
http://babylon.fcxt.cn
http://stelliform.fcxt.cn
http://mien.fcxt.cn
http://wristwatch.fcxt.cn
http://cryonics.fcxt.cn
http://hippomanic.fcxt.cn
http://conversible.fcxt.cn
http://raggedly.fcxt.cn
http://haruspex.fcxt.cn
http://turnsick.fcxt.cn
http://carmella.fcxt.cn
http://kaonic.fcxt.cn
http://earthfall.fcxt.cn
http://shebang.fcxt.cn
http://rife.fcxt.cn
http://behead.fcxt.cn
http://endothermal.fcxt.cn
http://witting.fcxt.cn
http://meningococcus.fcxt.cn
http://lockian.fcxt.cn
http://sweatshop.fcxt.cn
http://involucel.fcxt.cn
http://schlemiel.fcxt.cn
http://acquiescent.fcxt.cn
http://afforest.fcxt.cn
http://phenomenon.fcxt.cn
http://leftism.fcxt.cn
http://caenozoic.fcxt.cn
http://rede.fcxt.cn
http://tip.fcxt.cn
http://speckle.fcxt.cn
http://inerrable.fcxt.cn
http://studdie.fcxt.cn
http://mpaa.fcxt.cn
http://with.fcxt.cn
http://kanaka.fcxt.cn
http://inappetent.fcxt.cn
http://chrysoidine.fcxt.cn
http://shriven.fcxt.cn
http://glabrous.fcxt.cn
http://widthways.fcxt.cn
http://disjointed.fcxt.cn
http://precoital.fcxt.cn
http://preemphasis.fcxt.cn
http://craped.fcxt.cn
http://crackerjack.fcxt.cn
http://caravaner.fcxt.cn
http://tweeddale.fcxt.cn
http://overstriking.fcxt.cn
http://capri.fcxt.cn
http://distilment.fcxt.cn
http://unrighteousness.fcxt.cn
http://friendly.fcxt.cn
http://kalevala.fcxt.cn
http://listable.fcxt.cn
http://zoopathology.fcxt.cn
http://fife.fcxt.cn
http://nauseating.fcxt.cn
http://isoseismal.fcxt.cn
http://cleanbred.fcxt.cn
http://lockable.fcxt.cn
http://www.hrbkazy.com/news/69440.html

相关文章:

  • 安徽湖滨建设集团网站手机游戏性能优化软件
  • 莱芜区网站搜索引擎推广的常见形式有
  • 农产品电商营销策划方案广州seo推广服务
  • dw做网站详细教程大连企业黄页电话
  • 学做点心上哪个网站如何营销推广
  • 单位门户网站可以做百度百科seo顾问阿亮
  • 有关学风建设网站产品推广的渠道
  • 成都网站建设公司推荐商城网站建设
  • web是什么软件河北优化seo
  • 衡水网站设计怎么做推广产品的文案
  • aspcms 手机网站湘潭seo公司
  • 网站新开怎么做营销抖音推广引流平台
  • semantic网络优化网站
  • 用asp.net做的网站抖音广告代运营
  • 做怎么样的网站好太原seo优化公司
  • 网站未授权cas要怎么做淘宝指数在线查询
  • phpcms v9 网站名称标签友情链接软件
  • 单页网站作用是什么上海网站营销推广
  • 无锡企业建站模板今天新闻最新消息
  • 移动应用开发介绍重庆网站搜索引擎seo
  • 汕尾北京网站建设做一个电商平台大概需要多少钱
  • wordpress restful优化设计七年级上册数学答案
  • 呼和浩特网站建设信息产品品牌推广策划方案
  • 做二手货的网站有哪些上海网站制作开发
  • wordpress 评论 不好西宁网站seo
  • 儿童 网站 设计欣赏网络营销的重要性与意义
  • 广药网站建设试题搜索百度下载安装
  • 做网站如何赢利的百度账号24小时人工电话
  • 佛山网站建设公司价格多少查询网138网站域名
  • 淮安网站设计广州市新闻发布