剑指Offer的学习笔记(C#篇)-- 从上往下打印二叉树
题目描述
从上往下打印出二叉树的每个节点,同层节点从左至右打印。
一 . 题目解析
了解过二叉树就应该知道,二叉树存在三种遍历方法:前序遍历(根→左→右)、中序遍历(左→根→右)、后续遍历(左→右→根)。

自定义二叉树:
/// <summary>
/// 二叉树的节点定义
/// </summary>
/// <typeparam name="T">数据具体类型</typeparam>
public class Node<T>
{
public T data { get; set; } public Node<T> lchild { get; set; } public Node<T> rchild { get; set; } public Node()
{
} public Node(T data)
{
this.data = data;
} public Node(T data, Node<T> lchild, Node<T> rchild)
{
this.data = data;
this.lchild = lchild;
this.rchild = rchild;
}
}
看一下三种遍历的代码实现:这里涉及到双递归的方法。
//该方法为递归遍历,仅阐述一下方法,目的在于搞清楚他们之间的逻辑关系。
// 前序遍历
public void PreOrder(Node<T> node)
{
//根节点开始,不为空的话,执行下面代码。
if (node != null)
{
// 前序方向根->左->右
//输出跟节点,往下走。
Console.Write(node.data + " ");
//当左节点不为空,返回递归。左节点为空,往下走
PreOrder(node.lchild);
//当左节点为空,输入右节点递归。
PreOrder(node.rchild);
}
} // 中序遍历
public void MidOrder(Node<T> node)
{
if (node != null)
{
// 中序遍历方向,左->根->右
// 输入跟节点,左节点不为空,一直往下走,当左节点为空,输出最下面的左节点
MidOrder(node.lchild);
//输出
Console.Write(node.data + " ");
// 当每次输出一个左节点,如果他有右节点,递归右节点
MidOrder(node.rchild);
}
} // 后序遍历
public void PostOrder(Node<T> node)
{
if (node != null)
{
//后序遍历,左->右->根
//一直递归左节点不输出,直到最下面的左右节点都市空的,才输出
PostOrder(node.lchild);
PostOrder(node.rchild);
//输出
Console.Write(node.data + " ");
}
}
解释一下双递归:(遇到双递归问题时,当第一个递归执行的时候,第二个递归并不是不执行,而是先进栈,根据顺序来,简单明了的解释就是,第一个递归你该怎么走就怎么走,完全没什么可以阻挡你,第二个递归就不同了,他是在第一个递归的基础上执行的,但不是立刻执行,而是执行递归进栈,当第一个递归完全执行技术的时候,第二个递归出栈,开始慢慢执行!)

具体解释:

如上图所示,二叉树的基本遍历方法中并不存在题目要求的方法,因此,必须自定义一种方法实现要求。

经过思考,得出如下步骤:
(1)定义两个链表,一个作为寄存链表,一个用作与最后输出的链表。
(2)若根节点不为空,把根节点存在寄存链表里。
(3)接下来,把他放到最后输出的链表里,之后呢,如果这个节点还有左右子节点的话,把左右子节点依次存在寄存链表里面。
(4)执行(3)循环,当循环执行次数大于或者等于寄存链表的长度时,停止执行(因为每执行一次循环,就相当于把寄存链表里的数字存到输出链表里,当全搞定,自然停止。)
二 . 代码实现
using System.Collections.Generic;
/*
public class TreeNode
{
public int val;
public TreeNode left;
public TreeNode right;
public TreeNode (int x)
{
val = x;
}
}*/ class Solution
{
public List<int> PrintFromTopToBottom(TreeNode root)
{
// write code here
//定义输出链表List1和寄存链表List2
List<int> List1 = new List<int>();
List<TreeNode> List2 = new List<TreeNode>();
int i = ;
//根节点的添加方法
if (root != null)
{
List2.Add(root);
}
//(3)循环
while (i < List2.Count)
{
//定义一个节点Node1等于寄存链表中的第i个数
TreeNode Node1 = List2[i];
//给输出链表添加数据
List1.Add(Node1.val);
//左右子节点排队进入链表List2
if (Node1.left != null)
{
List2.Add(Node1.left);
}
if (Node1.right != null)
{
List2.Add(Node1.right);
}
//i的执行次数应等于二叉树节点数
i++;
}
return List1;
}
}
剑指Offer的学习笔记(C#篇)-- 从上往下打印二叉树的更多相关文章
- (剑指Offer)面试题23:从上到下打印二叉树
题目: 从上往下打印出二叉树的每个节点,同层节点从左至右打印. 思路: 很明显,这是一个广度优先遍历. 需要一个队列容器来保存结点,具体操作: 1.将根结点压入队列中,并打印根结点:如果根结点有子结点 ...
- 【剑指offer】面试题23:从上往下打印二叉树
题目: 从上往下打印出二叉树的每个节点,同层节点从左至右打印. 思路: bfs,队列. 注意,队列最后不要忘了pop(). 代码: /* struct TreeNode { int val; stru ...
- 《剑指offer》— JavaScript(22)从上往下打印二叉树
从上往下打印二叉树 题目描述 从上往下打印出二叉树的每个节点,同层节点从左至右打印. 思路 借助两个辅助队列,一个用来存放结点,一个用来存放结点值: 先将根节点加入到队列中,然后遍历队列中的元素,遍历 ...
- 【剑指Offer】面试题32 - III. 从上到下打印二叉树 III
题目 请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推. 例如: 给定二叉树: [3,9,20,nu ...
- 【剑指Offer】面试题32 - II. 从上到下打印二叉树 II
题目 从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行. 例如: 给定二叉树: [3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7 返回 ...
- 【剑指Offer】面试题32 - I. 从上到下打印二叉树
题目 从上到下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印. 例如: 给定二叉树: [3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7 返回: [3 ...
- 《剑指offer》面试题32 - I. 从上到下打印二叉树
问题描述 从上到下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印. 例如: 给定二叉树: [3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7 返回 ...
- 《剑指offer》面试题32 - II. 从上到下打印二叉树 II
问题描述 从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行. 例如: 给定二叉树: [3,9,20,null,null,15,7], 3 / \ 9 20 / \ 15 7 ...
- 《剑指offer》面试题32 - III. 从上到下打印二叉树 III
问题描述 请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推. 例如: 给定二叉树: [3,9,20, ...
- 剑指Offer的学习笔记(C#篇)-- 序列化二叉树
题目描述 请实现两个函数,分别用来序列化和反序列化二叉树 一 . 理解题意 二叉树的序列化,是将一个结构化的东西变成扁平化的字符串,序列化二叉树或者是反序列化二叉树就是二叉树和扩展二叉树遍历序列之间的 ...
随机推荐
- SSH Tunnel扫盲(ssh port forwarding端口转发)
SSH的的Port Forward,中文可以称为端口转发,是SSH的一项非常重要的功能.它可以建立一条安全的SSH通道,并把任意的TCP连接放到这条通道中.下面仔细就仔细讨论SSH的这种非常有用的功能 ...
- 《C prime plus (第五版)》 ---第11章 字符串和字符串函数---2
11-3:字符串 输出 三个标准的函数:puts() fputs() printf() 1.puts()函数: #include<stdio.h> #define DEF "I ...
- poj The Settlers of Catan( 求图中的最长路 小数据量 暴力dfs搜索(递归回溯))
The Settlers of Catan Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 1123 Accepted: ...
- MysqL的root用户不允许远程连接,只能通过PHPMYADMIN
解决方法:1.改表法 可能是你的帐号不允许从远程登陆,只能在localhost.这个时候只要在localhost的那台电脑,登入mysql后,更改 "mysql" 数据库里的 &q ...
- MySQL存储过程示例
MySQL存储过程: /*自定义结束符*/ DELIMITER $$ /*如果存在同名的存储过程就删除*/ DROP PROCEDURE IF EXISTS prAddBlack$$ /*创建存储过程 ...
- MD5算法的简单编写
package com.t_09; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; ...
- BZOJ1855 [Scoi2010]股票交易[单调队列dp]
题 题面有点复杂,不概括了. 后面的状态有前面的最优解获得大致方向是dp.先是瞎想了个$f[i][j]$表示第$i$天手里有$j$张股票时最大收入(当天无所谓买不买). 然后写了一个$O(n^4)$状 ...
- 「LOJ#10072」「一本通 3.2 例 1」Sightseeing Trip(无向图最小环问题)(Floyd
题目描述 原题来自:CEOI 1999 给定一张无向图,求图中一个至少包含 333 个点的环,环上的节点不重复,并且环上的边的长度之和最小.该问题称为无向图的最小环问题.在本题中,你需要输出最小环的方 ...
- uC/OS-II源码分析(三)
首先来了解下实时系统的基本概念: 1) 临界区,共享资源,任务(类似于进程),任务切换,任务调度,可剥夺型内核,可重入函数,动态优先级调度, 2) 如何处理优先级反转问题.这个问题描述如下:有三个任务 ...
- poj2955——括号匹配
题目:http://poj.org/problem?id=2955 区间DP. 代码如下: #include<iostream> #include<cstdio> #inclu ...