1110 Complete Binary Tree(测试点234 注意结点编号可以是2位数)

题目链接
借助队列来判断是否为完全二叉树,从根节点开始将左右孩子入队,当遇到第一个空结点时终止循环,判断队列剩余部分是否还有数字,如果有则不是完全二叉树,如果没有则就是完全二叉树。
这道题有点坑的地方是编号小于等于20,即有两位数,所以子结点读取的时候要用string类型才能和“-”统一读取,如果把结点当作个位数测试点234会过不了。

#include<bits/stdc++.h>
using namespace std;
int main(){
    int N;
    cin >> N;
    vector<vector<int> > t(N,vector<int>(2));
    vector<bool> vis(N,false);
    for(int i=0;i<N;i++){
        string a[2];
        cin >> a[0] >> a[1];
        for(int j=0;j<2;j++){
            if(a[j]=="-"){
                t[i][j]=-1;
            }else{
                int tmp=0;
                for(char c:a[j]){
                    tmp=tmp*10+c-'0';
                }
                t[i][j]=tmp;
                vis[tmp]=true;
            }
        }
        
        
    }
    int root=0;
    for(int i=0;i<N;i++){
        if(!vis[i]){
            root=i;
            break;
        }
    }
    //应该是借助队列来判断
    queue<int> q;
    q.push(root);
    int last=root;
    while(!q.empty()){
        if(q.front()==-1){
            break;
        }
        int node=q.front();
        last=node;
        q.pop();
        q.push(t[node][0]);
        q.push(t[node][1]);
    }
    //检查队列中是否都是-1
    bool f=true;
    while(!q.empty()){
        if(q.front()!=-1){
            f=false;
            break;
        }
        q.pop();
    }
    if(f){
        cout << "YES " << last;
    }else cout << "NO " << root;
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是用C语言实现判断二叉树是否为完全二叉树的代码: ```c #include <stdio.h> #include <stdlib.h> // 定义二叉树结点 struct Node { int val; struct Node *left, *right; }; // 计算二叉树的结点数量 int countNodes(struct Node* root) { if (root == NULL) { return 0; } return 1 + countNodes(root->left) + countNodes(root->right); } // 判断二叉树是否为完全二叉树 int isCompleteTree(struct Node* root, int index, int numNodes) { // 如果为空树,返回true if (root == NULL) { return 1; } // 如果当前结点的索引超过了结点数量,返回false if (index >= numNodes) { return 0; } // 递归判断左右子树是否为完全二叉树 return isCompleteTree(root->left, 2 * index + 1, numNodes) && isCompleteTree(root->right, 2 * index + 2, numNodes); } int main() { // 创建一个二叉树 struct Node* root = (struct Node*)malloc(sizeof(struct Node)); root->val = 1; root->left = (struct Node*)malloc(sizeof(struct Node)); root->left->val = 2; root->left->left = (struct Node*)malloc(sizeof(struct Node)); root->left->left->val = 4; root->left->right = (struct Node*)malloc(sizeof(struct Node)); root->left->right->val = 5; root->right = (struct Node*)malloc(sizeof(struct Node)); root->right->val = 3; root->right->left = (struct Node*)malloc(sizeof(struct Node)); root->right->left->val = 6; int nodeCount = countNodes(root); int index = 0; if (isCompleteTree(root, index, nodeCount)) { printf("This is a complete binary tree.\n"); } else { printf("This is not a complete binary tree.\n"); } return 0; } ``` 该程序首先定义了一个二叉树结点的结构体,包含结点值、左右子树的指针。接着定义了两个函数: - `countNodes`:计算二叉树的结点数量,使用递归方式遍历二叉树,每遍历一个结点,就累加1,最终返回结点数量。 - `isCompleteTree`:判断二叉树是否为完全二叉树,使用递归方式遍历二叉树,同时记录每个结点的索引。如果当前结点的索引超过了结点数量,说明已经遍历到了不存在的结点,因此返回false。如果当前结点的索引小于结点数量,就继续递归遍历它的左右子树,直到遍历完整棵树。如果递归过程中没有返回false,说明该树是完全二叉树,返回true。 在主函数中,我们创建了一个二叉树,并调用`countNodes`计算结点数量,调用`isCompleteTree`判断二叉树是否为完全二叉树。最终根据返回值输出判断结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值