常用数据结构算法 : 完全二叉树判别

import java.util.LinkedList;
import java.util.Queue;

/**********************************************************
 * 非递归方法,基本是层次遍历二叉树 依次检查每一个节点:
 * 1.当发现有一个节点的左子树为空,右子树不为空时 直接返回false.
 * 2.当发现有一个节点的左子树不为空,右子树为空时,置标志位为1。
 * 3.当发现有一个节点的左右子树均为空时,置标志位为1。
 **********************************************************/

public class CompleteBinaryTree
{
    //检查一棵树是不是完全二叉树
    public boolean checking(TreeNode root)
    {
        Queue<TreeNode> queue = new LinkedList<TreeNode>();
        boolean flag = false; // 叶子结点
        TreeNode left;
        TreeNode right;
        queue.add(root);
        while (!queue.isEmpty()) {
            root = queue.poll();
            left = root.left;
            right = root.right;

            if ((flag && (left != null || right != null)) || (left == null && right != null)) {
                // 如果之前层遍历的结点没有右孩子,且当前的结点有左或右孩子,直接返回false
                // 如果当前结点有右孩子却没有左孩子,直接返回false
                return false;
            }

            if (left != null) queue.offer(root.left);

            if (right != null)queue.offer(root.right);
            else flag = true; // 如果当前结点没有右孩子,那么之后层遍历到的结点必须为叶子结点

        }
        return true;
    }
}
时间: 2024-10-05 16:18:04

常用数据结构算法 : 完全二叉树判别的相关文章

常用数据结构算法 : 大数的加减

package wellhold.algorithm.bigInteger; public class BigDataPlus { public static void main(String[] args) { System.out.println(Plus("92321231", "12345123123")); } public static String Plus(String num1,String num2) { num1=new StringBuffe

常用数据结构及算法C#实现

常用数据结构及算法C#实现 1.冒泡排序.选择排序.插入排序(三种简单非递归排序) 1 int[] waitSort = { 1,0, 12, 13, 14, 5, 6, 7, 8, 9, 10 }; 2 3 //冒泡排序 4 int length = waitSort.Length; 5 6 for (int i = 0; i < length; i++) 7 { 8 for (int j = i + 1; j < length; j++) 9 { 10 if (waitSort[j] &g

算法数据结构02 /常用数据结构

目录 2算法数据结构02 /常用数据结构 1. 栈 2. 队列 3. 双端队列 4. 内存相关 5. 顺序表 6. 链表 7. 二叉树 2算法数据结构02 /常用数据结构 1. 栈 特性:先进后出的数据结构,有栈顶和栈尾 应用场景:每个 web 浏览器都有一个返回按钮.浏览网页时,这些网页被放置在一个栈中(实际是网页的网址).现在查看的网页在顶部,第一个查看的网页在底部.如果按'返回'按钮,将按相反的顺序浏览刚才的页面. 栈的方法: Stack():创建一个空的新栈. 它不需要参数,并返回一个空

视觉直观感受7种常用排序算法

视觉直观感受若干常用排序算法 1 快速排序 介绍: 快速排序是由东尼·霍尔所发展的一种排序算法.在平均状况下,排序 n 个项目要Ο(n log n)次比较.在最坏状况下则需要Ο(n2)次比较,但这种状况并不常见.事实上,快速排序通常明显比其他Ο(n log n) 算法更快,因为它的内部循环(inner loop)可以在大部分的架构上很有效率地被实现出来,且在大部分真实世界的数据,可以决定设计的选择,减少所需时间的二次方项之可能性. 步骤: 从数列中挑出一个元素,称为 "基准"(pivo

java 常用数据结构

本章介绍Java的实用工具类库java.util包.在这个包中,Java提供了一些实用的方法和数据结构.例如,Java提供日期(Data)类.日 历(Calendar)类来产生和获取日期及时间,提供随机数(Random)类产生各种类型的随机数,还提供了堆栈(Stack).向量 (Vector) .位集合(Bitset)以及哈希表(Hashtable)等类来表示相应的数据结构. 图1.1给出了java.util包的基本层次结构图.下面我们将具体介绍其中几个重要的类. ┌java.util.BitS

常用排序算法的python实现

排序算是编程最基本的算法问题之一了,熟练掌握排序算法也能加深自己对数据结构的理解,也能提高自己的编程能力,以下为个人参考许多大神博客后对常用排序算法的学习总结. 目录: 概述 冒泡排序 直接插入排序 简单选择排序 希尔排序 堆排序 归并排序 快速排序 算法的比较与测试 参考 1. 概述 所谓排序(sorting)就是整理数据的序列,使其按照特定顺序排列的操作.排序在现实生活中(如整理书籍,表格数据等),在计算领域中(如二分查找,图论的最小生成树的Kruskal算法)均有重要意义,所以一种高效的排

第4章 数据结构算法

py内置数据结构算法常考 常用内置的算法和数据结构 sorted list/set/dict/tuple 常用内置数据结构和算法 数据结构/算法 语言内置 内置库 线性结构 list(列表)/tuple(元组) array(数组, 不常用)/collections.namedtuple 链式结构 collections.deque(双端队列) 字典结构 dict(集合) collections.Counte(计数器)/OrderedDict(有序字典) 集合结构 set(集合)/frozense

DotNet常用排序算法总结

数据结构和算法对一个程序来说是至关重要的,现在介绍一下几种算法,在项目中较为常用的算法有:冒泡排序,简单选择排序,直接插入排序,希尔排序,堆排序,归并排序,快速排序等7中算法. 现在介绍选择排序算法,希尔排序算法,快速排序算法. (1).选择排序算法:通过n-i次关键字间的比较,从n-i+1个记录中选择出关键字最小的记录,并和第i(1大于等于i小于等于n)个记录交换. (2).希尔排序:先取一个小于n的整数d1作为第一个增量,把文件的全部记录分组.所有距离为d1的倍数的记录放在同一个组中.先在各

Java常用排序算法+程序员必须掌握的8大排序算法+二分法查找法

Java 常用排序算法/程序员必须掌握的 8大排序算法 本文由网络资料整理转载而来,如有问题,欢迎指正! 分类: 1)插入排序(直接插入排序.希尔排序) 2)交换排序(冒泡排序.快速排序) 3)选择排序(直接选择排序.堆排序) 4)归并排序 5)分配排序(基数排序) 所需辅助空间最多:归并排序 所需辅助空间最少:堆排序 平均速度最快:快速排序 不稳定:快速排序,希尔排序,堆排序. 先来看看 8种排序之间的关系: 1.直接插入排序 (1)基本思想:在要排序的一组数中,假设前面(n-1)[n>=2]