欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來到入門教程網(wǎng)!

Java編程

當(dāng)前位置:主頁 > 軟件編程 > Java編程 >

判斷二叉樹是否為完全二叉樹的實例

來源:本站原創(chuàng)|時間:2020-01-10|欄目:Java編程|點擊: 次

完全二叉樹特點

完全二叉樹是指除了最后一層之外,其他每一層的結(jié)點數(shù)都是滿的。最后一層如果也滿了,是一顆滿二叉樹,也是完全二叉樹。最后一層如果不滿,缺少的結(jié)點也全部的集中在左邊,那也是一顆完全二叉樹。

判斷一棵二叉樹是否為完全二叉樹

import java.util.*;
class TreeNode {
  int val = 0;
  TreeNode left = null;
  TreeNode right = null;
  public TreeNode(int val) {
    this.val = val;
  }
}
public class CheckCompletion {
  public boolean checking(TreeNode root) {
    Queue<TreeNode> queue = new LinkedList<TreeNode>();
    boolean leaf = false; // 葉子結(jié)點
    TreeNode left;
    TreeNode right;
    queue.add(root);
    while (!queue.isEmpty()) {
      root = queue.poll();
      left = root.left;
      right = root.right;
      if ((leaf&&(left!=null||right!=null)) || (left==null&&right!=null)) {
        // 如果之前層遍歷的結(jié)點沒有右孩子,且當(dāng)前的結(jié)點有左或右孩子,直接返回false
        // 如果當(dāng)前結(jié)點有右孩子卻沒有左孩子,直接返回false
        return false;
      }
      if (left != null) {
        queue.offer(root.left);
      }
      if (right != null) {
        queue.offer(root.right);
      }else {
        leaf = false; // 如果當(dāng)前結(jié)點沒有右孩子,那么之后層遍歷到的結(jié)點必須為葉子結(jié)點
      }
    }
    return true;
  }
}

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

上一篇:Java編程實現(xiàn)遞增排序鏈表的合并

欄    目:Java編程

下一篇:Java編程基礎(chǔ)測試題分享

本文標題:判斷二叉樹是否為完全二叉樹的實例

本文地址:http://mengdiqiu.com.cn/a1/Javabiancheng/8463.html

網(wǎng)頁制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫服務(wù)器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時內(nèi)進行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有