满二叉树是一类二叉树,其中每个结点恰好有 0 或 2 个子结点。

返回包含 N 个结点的所有可能满二叉树的列表。 答案的每个元素都是一个可能树的根结点。

答案中每个树的每个结点都必须有 node.val=0

你可以按任何顺序返回树的最终列表。

示例:

输入:7
输出:[[0,0,0,null,null,0,0,null,null,0,0],[0,0,0,null,null,0,0,0,0],[0,0,0,0,0,0,0],[0,0,0,0,0,null,null,null,null,0,0],[0,0,0,0,0,null,null,0,0]]
解释:

提示:

  • 1 <= N <= 20

递归做的,

贴代码:

public List<TreeNode> allPossibleFBT(int N) {
List<TreeNode>list=new ArrayList<TreeNode>();
TreeNode node=new TreeNode(0);
if(N==0)
return null;
if(N==1){
list.add(node);
return list;
} else{
List<TreeNode>list1=new ArrayList<TreeNode>();
for(int h=1;h<N-1;h++){
if(h%2==0)
continue;
List<TreeNode>left=allPossibleFBT(h);
List<TreeNode>right=allPossibleFBT(N-h-1);
if(h==3){
//System.out.println(right.size());
//System.out.println(right.get(0).left.val);
//System.out.println(right.get(0).right.right.val);
//System.out.println(right.get(1).left.left.val);
//System.out.println(right.get(1).right.val);
}
for(int j=0;j<left.size();j++){ for(int i=0;i<right.size();i++){
TreeNode node1=new TreeNode(0);
node1.left=left.get(j);
node1.right=right.get(i);
list1.add(node1);
}
}
}
return list1; } }

艾玛这题有点坑,刚开始我把TreeNode初始化放在第一层循环里面,结果解答错误,放在第二层循环就对了,求好心人告知这是什么原因,像下面这样。我是怎么发现这个的呢。我是实在找不到bug了,让一个大佬看看,然后他觉得放在里面好看于是挪进去,于是就通过了,我去,惊了。

897递增顺序查找树

给定一个树,按中序遍历重新排列树,使树中最左边的结点现在是树的根,并且每个结点没有左子结点,只有一个右子结点。

示例 :

输入:[5,3,6,2,4,null,8,1,null,null,null,7,9]

       5
/ \
3 6
/ \ \
2 4 8
 / / \
1 7 9 输出:[1,null,2,null,3,null,4,null,5,null,6,null,7,null,8,null,9] 1
  \
  2
  \
  3
  \
  4
  \
  5
  \
  6
  \
  7
  \
  8
  \
9

提示:

  1. 给定树中的结点数介于 1 和 100 之间。
  2. 每个结点都有一个从 0 到 1000 范围内的唯一整数值。

树的题目做多了,发现遍历很重要,前序、中序、后序和层次遍历都应该掌握

  public TreeNode increasingBST(TreeNode root) {
Stack <TreeNode>stack=new Stack<TreeNode>();
List<Integer>re=new ArrayList<Integer>();
int tag=0; while(root!=null||!stack.isEmpty()){
while(root!=null){
stack.push(root);
root=root.left;
}
if(!stack.isEmpty()){
TreeNode node=stack.pop();
re.add(node.val);
root=node.right;
}
}
TreeNode next=new TreeNode(re.get(re.size()-1));
for(int i=re.size()-2;i>=0;i--){
TreeNode node=new TreeNode(re.get(i));
node.right=next;
next=node;
}
return next;
}

919. 完全二叉树插入器

这题还是层次遍历的变形,当然我的这种做法并不好,用了243Ms,感觉快要超时了

class CBTInserter {
TreeNode root;
public CBTInserter(TreeNode root) {
this.root=root;
} public int insert(int v) {
Queue <TreeNode>queue=new LinkedList<TreeNode>();
queue.offer(root);
int re=0;
int flag=0;
while(!queue.isEmpty()){
for(int i=0;i<queue.size();i++){
TreeNode node=queue.poll();
if(node.left==null&&node.right==null){
node.left=new TreeNode(v);
re=node.val;
flag=1;
}
else if(node.right==null){
node.right=new TreeNode(v);
re=node.val;
flag=1;
}
else{
queue.offer(node.left);
queue.offer(node.right);
}
if(flag==1)
break; }
if(flag==1)
break;
}
return re; } public TreeNode get_root() { return root;
}
}

951.

翻转等价二叉树

简单的递归,嘿嘿

 public boolean flipEquiv(TreeNode root1, TreeNode root2) {
if(root1==null&&root2==null)
return true;
else if(root1==null||root2==null)
return false;
if(root1.val!=root2.val)
return false;
if(root1.left==null&&root1.right==null&&root2.left==null&&root2.right==null)
return true;
boolean judge1=flipEquiv(root1.left,root2.left)&&flipEquiv(root2.right,root1.right);
boolean judge2=flipEquiv(root1.left,root2.right)&&flipEquiv(root1.right,root2.left);
return judge1||judge2; }

leetcode树专题894.897,919,951的更多相关文章

  1. LeetCode树专题

    LeetCode树专题 98. 验证二叉搜索树 二叉搜索树,每个结点的值都有一个范围 /** * Definition for a binary tree node. * struct TreeNod ...

  2. LeetCode:树专题

    树专题 参考了力扣加加对与树专题的讲解,刷了些 leetcode 题,在此做一些记录,不然没几天就没印象了 力扣加加-树专题 总结 树的定义 // Definition for a binary tr ...

  3. LeetCode刷题 树专题

    树专题 关于树的几个基本概念 1 树的节点定义 2 关于二叉树的遍历方法 2.1 前序遍历 2.2 中序遍历 2.3 后序遍历 2.4 层序遍历 3 几种常见的树介绍 3.1 完全二叉树 3.2 二叉 ...

  4. LeetCode 字符串专题(一)

    目录 LeetCode 字符串专题 <c++> \([5]\) Longest Palindromic Substring \([28]\) Implement strStr() [\(4 ...

  5. zkw线段树专题

    题目来自大神博客的线段树专题 http://www.notonlysuccess.com/index.php/segment-tree-complete/ hdu1166 敌兵布阵题意:O(-1)思路 ...

  6. vj线段树专题

    vj线段树专题题解 单点更新模板 void build(int x,int l,int r){//sum[x]控制l-r区域 if(l==r){Sum[x]=num[l];return ;} int ...

  7. leetcode 树类型题

    树的测试框架: // leetcodeTree.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream& ...

  8. leetcode: 树

    1. sum-root-to-leaf-numbers Given a binary tree containing digits from0-9only, each root-to-leaf pat ...

  9. 《剑指offer》树专题 (牛客10.25)

    考察的知识点主要在于树的数据结构(BST,AVL).遍历方式(前序,中序,后序,层次).遍历算法(DFS,BFS,回溯)以及遍历时借助的数据结构如队列和栈.由于树本身就是一个递归定义的结构,所以在递归 ...

随机推荐

  1. “全栈2019”Java多线程第三十二章:显式锁Lock等待唤醒机制详解

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...

  2. USACO December 铂金Maxflow

    USACO 2015 December Contest, Platinum Problem 1. Max Flow Farmer John has installed a new system of ...

  3. 【kuangbin专题】计算几何基础

    1.poj2318 TOYS 传送:http://poj.org/problem?id=2318 题意:有m个点落在n+1个区域内.问落在每个区域的个数. 分析:二分查找落在哪个区域内.叉积判断点与线 ...

  4. 文件寄生——寻找宿主的不归路(NTFS文件流实际应用)

    咱们今天来研究下NTFS文件流: NTFS文件系统实现了多文件流特性,NTFS环境一个文件默认使用的是未命名的文件流,同时可创建其他命名的文件流,windows资源管理器默认不显示出文件的命名文件流, ...

  5. 传输层两大协议:TCP和UDP

    1. UDP 1.1 发送方式(如何发送) 面向无连接. 无状态服务. 不保证不丢失,不保证按顺序到达. 1.2 发送形式(发送的是什么) 基于数据报. 一个一个的发送,一个一个的接收. 1.3 使用 ...

  6. 移动一根火柴使等式成立js版本

    <html><head><meta http-equiv="Content-Type" content="text/html; charse ...

  7. linq查询时查询语句中附带多个查询时“已有打开的与此 Command 相关联的 DataReader,必须首先将它关闭”

    主要原因是因为EF采用的 DataReader来进行数据的存储,此时connection使用的是同一个. 例如: list = _tzNewsService.GetAll().Where(w => ...

  8. 【tomcat】servlet原理及其生命周期

    1.什么是servlet? Servlet(Servlet Applet),全称Java Servlet,是用Java编写的服务器端程序.而这些Servlet都要实现Servlet这个接口.其主要功能 ...

  9. 让机器说话(文字转美女语音,擅长中英文哦),大小600K(免费下载)!

    机器人之路的第二小步:说话(文字转语音美女哦),大小600K(免费下载)! 机器人之路的第二小步:说话(文字转语音美女哦),准确率特别高,普通话标准,中英文都可以说,大家可以体验一下,请下载到电脑上在 ...

  10. Java 多线程学习笔记:生产者消费者问题

    前言:最近在学习Java多线程,看到ImportNew网上有网友翻译的一篇文章<阻塞队列实现生产者消费者模式>.在文中,使用的是Java的concurrent包中的阻塞队列来实现.在看完后 ...