Leetcode题解(30)
98. Validate Binary Search Tree
题目
分析:BST按照中序遍历之后所得到的序列是一个递增序列,因此可以按照这个思路,先中序遍历,保存好遍历的结果,然后在遍历一遍这个序列。判断其是否递增
代码如下:
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
bool isValidBST(TreeNode* root) {
if(NULL == root)
return true;
vector<int> res;
inOrderTraversal(root,res);
for(int i=;i<res.size();i++)
{
if(res[i]<=res[i-])
return false;
}
return true;
}
void inOrderTraversal(TreeNode* root,vector<int> &res)
{
if(NULL==root)
return;
inOrderTraversal(root->left,res);
res.push_back(root->val);
inOrderTraversal(root->right,res); }
};
上面的实现中,使用了一个vector,需要额外的O(n)空间,但是仔细一想,当在保存某一个之值时,只需要判断在它之前的那个数是否小于它,如果小于,则继续遍历,如果不小于,则可以返回false。
代码如下,每次递归调用的时候,都将当前已经遍历的最大数字保存在key中即可
/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
bool isValidBST(TreeNode* root) {
if(NULL == root)
return true; long long key = -;
return inOrderTraversal(root,key); }
bool inOrderTraversal(TreeNode* root,long long &key)
{
if(NULL==root)
return true;
bool flag = inOrderTraversal(root->left,key);
if(flag == false)
return false;
if(root->val <= key)
{
return false;
}
key = root->val;
flag = inOrderTraversal(root->right,key);
if(flag == false)
return false;
return true; }
};
-----------------------------------------------------------------------------------------分割线---------------------------------------------------------------------------------
100. Same Tree
题目
分析:
判断两棵树结构是否相同,只需要递归判断其左右子树是否分别相同,并且当前节点的值也相同即可。
代码如下:
/**
* Definition for binary tree
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
bool isSameTree(TreeNode *p, TreeNode *q) {
if (NULL == p && NULL == q)
{
return true;
}
else if (NULL != p && NULL == q)
{
return false;
}
else if (NULL == p && NULL != q)
{
return false;
} if (p->val != q->val)
{
return false;
} return isSameTree(p->left,q->left)&&isSameTree(p->right,q->right); }
};
--------------------------------------------------------------------------------------分割线----------------------------------------------------------------------------------
101. Symmetric Tree
题目
分析:
这道题目,其实就是二叉树广度优先遍历的变形,只是每次入队列的方式和广度优先遍历算法中入队列的方式不同,详细见代码
/**
* Definition for binary tree
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
bool isSymmetric(TreeNode *root) {
queue<TreeNode *> myQueue;
if (NULL == root)
{
return true;
}
if (NULL != root->left && NULL != root->right)
{
myQueue.push(root->left);
myQueue.push(root->right);
}
else if (NULL == root->left && NULL == root->right)
{
return true;
}
else
return false; TreeNode *temp1,*temp2; while(!myQueue.empty())
{
temp1 = myQueue.front();
myQueue.pop();
temp2 = myQueue.front();
myQueue.pop();
if (NULL == temp1 && NULL == temp2)
{
continue;
}
else if (NULL != temp1 && NULL == temp2)
{
return false;
}
else if (NULL == temp1 && NULL != temp2)
{
return false;
}
else if (temp1->val == temp2->val)
{
myQueue.push(temp1->left);//左节点
myQueue.push(temp2->right);//右节点
myQueue.push(temp1->right);
myQueue.push(temp2->left);
}
else
return false; }
return true; }
};
----------------------------------------------------------------------------------------------分割线----------------------------------------------------------------------------
102. Binary Tree Level Order Traversal
题目
分析:
二叉树的广度优先遍历,代码如下:
/**
* Definition for binary tree
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
vector<vector<int> > levelOrder(TreeNode *root) {
vector<vector<int> > res;
stack<vector<int> > tempStack; vector<int> temp;
TreeNode *pNode=NULL;
temp.clear();
res.clear();
if (NULL == root)
{
return res;
} queue<TreeNode *> myQue;
myQue.push(root);
while (!myQue.empty())
{
myQue.push(NULL);//通过NULL标志进行分层
temp.clear();
pNode = myQue.front();
myQue.pop();
while (NULL != pNode)
{
temp.push_back(pNode->val);
if (NULL != pNode->left)
{
myQue.push(pNode->left);
}
if (NULL != pNode->right)
{
myQue.push(pNode->right);
}
pNode = myQue.front();
myQue.pop(); } res.push_back(temp); }
return res;
}
};
Leetcode题解(30)的更多相关文章
- [LeetCode 题解]: plusOne
前言 [LeetCode 题解]系列传送门: http://www.cnblogs.com/double-win/category/573499.html 1.题目描述 Given a no ...
- [LeetCode 题解]: ZigZag Conversion
前言 [LeetCode 题解]系列传送门: http://www.cnblogs.com/double-win/category/573499.html 1.题目描述 The string ...
- 【LeetCode题解】二叉树的遍历
我准备开始一个新系列[LeetCode题解],用来记录刷LeetCode题,顺便复习一下数据结构与算法. 1. 二叉树 二叉树(binary tree)是一种极为普遍的数据结构,树的每一个节点最多只有 ...
- leetcode题解-122买卖股票的最佳时期
题目 leetcode题解-122.买卖股票的最佳时机:https://www.yanbinghu.com/2019/03/14/30893.html 题目详情 给定一个数组,它的第 i 个元素是一支 ...
- 【LeetCode题解】3_无重复字符的最长子串(Longest-Substring-Without-Repeating-Characters)
目录 描述 解法一:暴力枚举法(Time Limit Exceeded) 思路 Java 实现 Python 实现 复杂度分析 解法二:滑动窗口(双指针) 思路 Java 实现 Python 实现 复 ...
- 【LeetCode题解】225_用队列实现栈(Implement-Stack-using-Queues)
目录 描述 解法一:双队列,入快出慢 思路 入栈(push) 出栈(pop) 查看栈顶元素(peek) 是否为空(empty) Java 实现 Python 实现 解法二:双队列,入慢出快 思路 入栈 ...
- 【LeetCode题解】232_用栈实现队列(Implement-Queue-using-Stacks)
目录 描述 解法一:在一个栈中维持所有元素的出队顺序 思路 入队(push) 出队(pop) 查看队首(peek) 是否为空(empty) Java 实现 Python 实现 解法二:一个栈入,一个栈 ...
- 【LeetCode题解】844_比较含退格的字符串(Backspace-String-Compare)
目录 描述 解法一:字符串比较 思路 Java 实现 Python 实现 复杂度分析 解法二:双指针(推荐) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解笔记可以 ...
- 【LeetCode题解】25_k个一组翻转链表(Reverse-Nodes-in-k-Group)
目录 描述 解法一:迭代 思路 Java 实现 Python 实现 复杂度分析 解法二:递归(不满足空间复杂度) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解笔记 ...
- 【LeetCode题解】24_两两交换链表中的节点(Swap-Nodes-in-Pairs)
目录 描述 解法一:迭代 思路 Java 实现 Python 实现 复杂度分析 解法二:递归(不满足空间复杂度要求) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解 ...
随机推荐
- RocketMQ之双Master方式部署以及简单使用
1.1.服务器环境 192.168.100.24 root nameServer1,brokerServer1 Master1 192.168.100.25 root nameServer2,brok ...
- datepickerpopup时间限制选取
使用popup组件的过程中遇到时间选取的问题 官方文档大致说使用date和mode 可以解决,奈何老夫是看不懂,写的时候参考的有 官方文档.echo2016的博文.liumang361的博文 先看图 ...
- myeclipse一些快捷键 错了或者没说到补充下
Ctrl + 1 快速修复Ctrl + D 删除当前行 Ctrl + Alt + ↓ 复制当前行到下一行(复制增加)Ctrl + Alt + ↑ 复制当前行到上一行(复制增加)Alt + ↓ 当前行 ...
- epoll的ET和LT两种模式对比及注意事项
ET模式: 因为ET模式只有从unavailable到available才会触发,所以 1.读事件:需要使用while循环读取完,一般是读到EAGAIN,也可以读到返回值小于缓冲区大小: 如果应用层读 ...
- XCode消除警告、错误
1.集成支付宝SDK后,报一堆warning: (arm64) /Users/scmbuild/workspace/standard-pay/.....警告 解决方法: 1) Go to Build ...
- String的replace和replaceAll
replace(CharSequence target, CharSequence replacement) 这里CharSequence是一个接口 实现类包括CharBuffer, Segement ...
- Java 自增(++) 和 C语言中自增的区别
在Java.c语言等高级语言中自增和自减的作用基本一致,都是变量自身加一或减一.下面我只对自增进行说明,自减是类似的. 自增运算符(++),有两种书写形式,一个是在变量前: ++ num; 另一种在变 ...
- Nginx 1.10.1 版本nginx.conf优化配置及详细注释
Nginx 1.10.1 的nginx.conf文件,是调优后的,可以拿来用,有一些设置无效,我备注上了,不知道是不是版本的问题,回头查一下再更正. #普通配置 #==性能配置 #运行用户 user ...
- 富文本编辑器CKEditor的使用
由于最近在架构一个pc端b/s结构的项目,项目中有个论坛模块,当用户发帖时,需要用到富文本编辑器,考虑了一下,决定使用CKEditor富文本编辑器,虽然现在问世的富文本编辑器很丰富,比如还有百度的UE ...
- C-一行或多行文章垂直居中
1 样式效果 2 table布局 li span