6-6 F. DS二叉树——二叉树之数组存储

题目描述

二叉树可以采用数组的方法进行存储,把数组中的数据依次自上而下,自左至右存储到二叉树结点中,一般二叉树与完全二叉树对比,比完全二叉树缺少的结点就在数组中用0来表示。

右边的是一颗普通的二叉树,当它与左边的完全二叉树对比,发现它比完全二叉树少了第5号结点,所以在数组中用0表示,同样它还少了完全二叉树中的第10、11号结点,所以在数组中也用0表示。

结点存储的数据均为非负整数

输入

第一行输入一个整数t,表示有t个二叉树

第二行起,每行输入一个数组,先输入数组长度,再输入数组内数据,每个数据之间用空格隔开,输入的数据都是非负整数

连续输入t行

输入样例:

3

3 1 2 3

5 1 2 3 0 4

13 1 2 3 4 0 5 6 7 8 0 0 9 10

输出

每行输出一个示例的先序遍历结果,每个结点之间用空格隔开

输出样例:

1 2 3

1 2 4 3

1 2 4 7 8 3 5 9 10 6

代码

cpp 复制代码
#include <iostream>
using namespace std;

class Tree{
public:
    int len;
    int *arr;
    Tree(){
        cin >> len;
        arr = new int[len];
        for(int i = 0; i < len; i++){
            cin >> arr[i];
        }
    }

    void DLR(int i){
        if(arr[i] != 0 && i < len){
            cout << arr[i] << " ";
            DLR(i*2+1);
            DLR(i*2+2);
        }
    }
};

int main()
{
    int t;
    cin >> t;
    while(t--){
        Tree tree;
        tree.DLR(0);
        cout << endl;
    }
    return 0;
}
相关推荐
红纸2813 分钟前
Subword算法之WordPiece、Unigram与SentencePiece
人工智能·python·深度学习·神经网络·算法·机器学习·自然语言处理
CUMT_DJ43 分钟前
从零复现论文(1)——通感一体化实现协作基站分配与资源分配(CBARA)策略
算法·通感一体化
tt5555555555551 小时前
CSDN 教程:C++ 经典字符串与栈算法题逐行详解
c++·算法·哈希算法
周杰伦fans1 小时前
C++ 中的 `::` 全局作用域符
开发语言·c++
_dindong1 小时前
基础算法:滑动窗口
数据结构·学习·算法·leetcode·力扣
bkspiderx2 小时前
C++设计模式之行为型模式:状态模式(State)
c++·设计模式·状态模式
Voyager_42 小时前
图像处理踩坑:浮点数误差导致的缩放尺寸异常与解决办法
数据结构·图像处理·人工智能·python·算法
会开花的二叉树2 小时前
分布式文件存储 RPC 服务实现
c++·分布式·网络协议·rpc
文艺倾年2 小时前
【八股消消乐】手撕分布式协议和算法(基础篇)
分布式·算法
abcd_zjq2 小时前
VS2026+QT6.9+opencv图像增强(多帧平均降噪)(CLAHE对比度增强)(边缘增强)(图像超分辨率)
c++·图像处理·qt·opencv·visual studio