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)的更多相关文章

  1. [LeetCode 题解]: plusOne

    前言   [LeetCode 题解]系列传送门:  http://www.cnblogs.com/double-win/category/573499.html   1.题目描述 Given a no ...

  2. [LeetCode 题解]: ZigZag Conversion

    前言   [LeetCode 题解]系列传送门:  http://www.cnblogs.com/double-win/category/573499.html   1.题目描述 The string ...

  3. 【LeetCode题解】二叉树的遍历

    我准备开始一个新系列[LeetCode题解],用来记录刷LeetCode题,顺便复习一下数据结构与算法. 1. 二叉树 二叉树(binary tree)是一种极为普遍的数据结构,树的每一个节点最多只有 ...

  4. leetcode题解-122买卖股票的最佳时期

    题目 leetcode题解-122.买卖股票的最佳时机:https://www.yanbinghu.com/2019/03/14/30893.html 题目详情 给定一个数组,它的第 i 个元素是一支 ...

  5. 【LeetCode题解】3_无重复字符的最长子串(Longest-Substring-Without-Repeating-Characters)

    目录 描述 解法一:暴力枚举法(Time Limit Exceeded) 思路 Java 实现 Python 实现 复杂度分析 解法二:滑动窗口(双指针) 思路 Java 实现 Python 实现 复 ...

  6. 【LeetCode题解】225_用队列实现栈(Implement-Stack-using-Queues)

    目录 描述 解法一:双队列,入快出慢 思路 入栈(push) 出栈(pop) 查看栈顶元素(peek) 是否为空(empty) Java 实现 Python 实现 解法二:双队列,入慢出快 思路 入栈 ...

  7. 【LeetCode题解】232_用栈实现队列(Implement-Queue-using-Stacks)

    目录 描述 解法一:在一个栈中维持所有元素的出队顺序 思路 入队(push) 出队(pop) 查看队首(peek) 是否为空(empty) Java 实现 Python 实现 解法二:一个栈入,一个栈 ...

  8. 【LeetCode题解】844_比较含退格的字符串(Backspace-String-Compare)

    目录 描述 解法一:字符串比较 思路 Java 实现 Python 实现 复杂度分析 解法二:双指针(推荐) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解笔记可以 ...

  9. 【LeetCode题解】25_k个一组翻转链表(Reverse-Nodes-in-k-Group)

    目录 描述 解法一:迭代 思路 Java 实现 Python 实现 复杂度分析 解法二:递归(不满足空间复杂度) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解笔记 ...

  10. 【LeetCode题解】24_两两交换链表中的节点(Swap-Nodes-in-Pairs)

    目录 描述 解法一:迭代 思路 Java 实现 Python 实现 复杂度分析 解法二:递归(不满足空间复杂度要求) 思路 Java 实现 Python 实现 复杂度分析 更多 LeetCode 题解 ...

随机推荐

  1. RocketMQ之双Master方式部署以及简单使用

    1.1.服务器环境 192.168.100.24 root nameServer1,brokerServer1 Master1 192.168.100.25 root nameServer2,brok ...

  2. datepickerpopup时间限制选取

    使用popup组件的过程中遇到时间选取的问题 官方文档大致说使用date和mode 可以解决,奈何老夫是看不懂,写的时候参考的有 官方文档.echo2016的博文.liumang361的博文 先看图 ...

  3. myeclipse一些快捷键 错了或者没说到补充下

    Ctrl + 1 快速修复Ctrl + D  删除当前行 Ctrl + Alt + ↓ 复制当前行到下一行(复制增加)Ctrl + Alt + ↑ 复制当前行到上一行(复制增加)Alt + ↓ 当前行 ...

  4. epoll的ET和LT两种模式对比及注意事项

    ET模式: 因为ET模式只有从unavailable到available才会触发,所以 1.读事件:需要使用while循环读取完,一般是读到EAGAIN,也可以读到返回值小于缓冲区大小: 如果应用层读 ...

  5. XCode消除警告、错误

    1.集成支付宝SDK后,报一堆warning: (arm64) /Users/scmbuild/workspace/standard-pay/.....警告 解决方法: 1)  Go to Build ...

  6. String的replace和replaceAll

    replace(CharSequence target, CharSequence replacement) 这里CharSequence是一个接口 实现类包括CharBuffer, Segement ...

  7. Java 自增(++) 和 C语言中自增的区别

    在Java.c语言等高级语言中自增和自减的作用基本一致,都是变量自身加一或减一.下面我只对自增进行说明,自减是类似的. 自增运算符(++),有两种书写形式,一个是在变量前: ++ num; 另一种在变 ...

  8. Nginx 1.10.1 版本nginx.conf优化配置及详细注释

    Nginx 1.10.1 的nginx.conf文件,是调优后的,可以拿来用,有一些设置无效,我备注上了,不知道是不是版本的问题,回头查一下再更正. #普通配置 #==性能配置 #运行用户 user ...

  9. 富文本编辑器CKEditor的使用

    由于最近在架构一个pc端b/s结构的项目,项目中有个论坛模块,当用户发帖时,需要用到富文本编辑器,考虑了一下,决定使用CKEditor富文本编辑器,虽然现在问世的富文本编辑器很丰富,比如还有百度的UE ...

  10. C-一行或多行文章垂直居中

    1 样式效果 2 table布局 li span