数据结构 二叉树问题

论坛 期权论坛 期权     
数竞爱好者   2018-4-26 13:43   3229   2
n个结点的完全二叉树按顺序存储在一维数组中,设计一个算法,实现对此二叉树的先序遍历。


输入描述

首先输入整数n,随后输入n个正整数


输出描述

二叉树先序遍历的结果,输出数据之间空一格。


输入样例

4
2 4 3 1


输出样例

2 ...n个结点的完全二叉树按顺序存储在一维数组中,设计一个算法,实现对此二叉树的先序遍历。

输入描述

首先输入整数n,随后输入n个正整数

输出描述

二叉树先序遍历的结果,输出数据之间空一格。

输入样例

4
2 4 3 1

输出样例

2 4 1 3展开
分享到 :
0 人收藏

2 个回复

倒序浏览
2#
laughlee7468  3级会员 | 2018-4-30 02:31:00 发帖IP地址来自
const int MaxSize = 1000;
void preorder(int *tree, int size, int root)
{
    if(root >= size)
        return;
    int lchild = root * 2 + 1, rchild = root * 2 + 2;
    printf("%d ", tree[root]);
    preorder(tree, size, lchild);
    preorder(tree, size, rchild);
}
void main( )
{
    int tree[MaxSize], n, i, root = 0;
    scanf("%d", &n);
    for(i = 0; i < n; i++)
        scanf("%d", &tree);
    printf("\n");
    preorder(tree, n, root);
}
3#
qq906237201  4级常客 | 2018-4-30 02:31:01 发帖IP地址来自

#include
#include
#include

using namespace std;
class Nodes
{
public:

聽 聽int val;

聽 聽Nodes *left;

聽 聽Nodes *right;

聽 聽Nodes(int tmp =0):val(tmp),left(nullptr),right(nullptr)

聽 聽{


聽 聽}

};
Nodes * CreateTree( vector &nodes);
void LeftAndRight(vector &nodes,vector &leftrst,vector &rightrst);
void OutPut(Nodes *pppNode);
////////////////////////////////////////////////////////////////////////
int main(int argc, char *argv[])
{

聽 聽int nodeNum;

聽 聽cin>>nodeNum;


聽 聽vectorData;

聽 聽//int *rslt = new int[nodeNum]{0};

聽 聽int tmp;

聽 聽for(int i=0;i>tmp;

聽 聽 聽 聽Data.push_back(tmp);

聽 聽}

聽 聽Nodes * 聽pNodes{CreateTree( Data)};//根据值域构造树

聽 聽OutPut(pNodes);//根据树输出先根遍历的结果

聽 聽return 0;
}
////////////////////////////////////////////////////////////////////////
Nodes * CreateTree( vector &nodes)
{

聽 聽if(nodes.size() == 0)return nullptr;

聽 聽if(nodes.size() == 1)

聽 聽{

聽 聽 聽 聽Nodes *root{new Nodes(nodes.at(0))};

聽 聽 聽 聽return root;

聽 聽}

聽 聽if(nodes.size() == 2)

聽 聽{

聽 聽 聽 聽Nodes *root{new Nodes(nodes.at(0))};

聽 聽 聽 聽Nodes *leftnode{new Nodes(nodes.at(1))};

聽 聽 聽 聽root->left = leftnode;//如果只有2个节点一定是根节点和左节点,完全二叉树的定义

聽 聽 聽 聽return root;

聽 聽}

聽 聽if(nodes.size() == 3)

聽 聽{

聽 聽 聽 聽Nodes *root{new Nodes(nodes.at(0))};

聽 聽 聽 聽Nodes *leftnode{new Nodes(nodes.at(1))};

聽 聽 聽 聽Nodes *rightnode{new Nodes(nodes.at(2))};

聽 聽 聽 聽root->left = leftnode;

聽 聽 聽 聽root->right = rightnode;

聽 聽 聽 聽return root;

聽 聽}

聽 聽//如果大于三个节点就开始分解递推

聽 聽Nodes *root{new Nodes(nodes.at(0))};

聽 聽vectorleftnodes;//左子树的值域

聽 聽vectorrightnodes;//右子树的值域

聽 聽LeftAndRight(nodes,leftnodes,rightnodes);//从总值域里面分出左值域和右值域

聽 聽root->left = CreateTree( leftnodes);//根据值域构造左右子树

聽 聽root->right = CreateTree( rightnodes);



聽 聽return root;//返回整棵树
}
////////////////////////////////////////////////////////////////////////
void LeftAndRight(vector &nodes,vector &leftrst,vector &rightrst)
{//将值分为左子树的值和右子树的值

聽 聽int layer = static_cast(log2(static_cast(nodes.size()))) 聽+ 1;//树的层数

聽 聽for(int i=2;i
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:
帖子:
精华:
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP