IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> uva122 二叉树层序遍历/bfs -> 正文阅读

[数据结构与算法]uva122 二叉树层序遍历/bfs

uva 122

题目大意:给出一组二叉树的节点,输出层序遍历的结果,如果路径不完整,输出“not complete"

  • 如果采用数组下表体现位置关系的方法(下标为k的节点左右儿子分别为2k和2k+1),数组很容易溢出,或者说根本开不了如此巨大的数组(256个节点串成一条链),所以这种方法只适用于完全树

  • 还是得利用结构体模拟。主要需要实现:

    1. 树的建立:在读取输入时建立,对于跳跃的节点,插入able为0的节点链接即可,在后续判断时,必须able为1方可
    2. 遍历:层序遍历是广度优先,可以利用队列实现。最初push root进队列,此后每次取出一个节点,判断该节点的able,可以的话依次在队列尾插入该节点的左右孩子(注意非空),如此直至队列为空,即实现了层序遍历(bfs)
    3. 建立节点,不一定要用动态申请的方法。本题中节点数最多为256,完全可以用数组实现。具体做法是:开一个数组nodes存节点结构体,维护一个int值cnt,表示当前已生成节点个数,生成新节点指针即为nodes + ++cnt,记得初始化,这是结构体+指针的方法。还有数组+下标的方法,是将结构体中的成员都开一个数组,这些数组的下标都使用cnt
  • 关于二叉树的物理存储,如果使用静态方法,在其他情况下也是通用的。如果有频繁的添加与删除操作,一直增加的cnt就不合理了。所以可以维护一个“内存池”:将所有空闲的节点存入一个链表,新建时取走一个、销毁时插入一个。

#include <vector>
#include <iostream>
#include <queue>
#include <fstream>

using namespace std;

#define TEST 0
typedef struct Node *pNode;

struct Node
{
    int able;
    int v;
    pNode l, r;

    Node() : able(0), l(NULL), r(NULL) {}
};

pNode root;
vector<int> ans;
ofstream ofs;

void removeTree(pNode d)
{
    if (d == NULL)
        return;
    if (d->l)
        removeTree(d->l);
    if (d->r)
        removeTree(d->r);
    delete d;
}

bool readInput()
{
    while (getchar() != '(')
        continue;
    if (cin.peek() == ')')
        return false;
    int v;
    char c;
    pNode p = root;
    cin >> v;
    getchar();

    while (1)
    {
        c = getchar();
        if (c == 'L')
        {
            if (!p->l)
                p->l = new Node;
            p = p->l;
        }
        if (c == 'R')
        {
            if (!p->r)
                p->r = new Node;
            p = p->r;
        }
        if (c == ')')
            break;
    }
    p->able++;
    p->v = v;
    return true;
}

bool bfs()
{
    pNode cur;
    queue<pNode> q;
    q.push(root);
    while (q.size())
    {
        cur = q.front();
        q.pop();
        if (cur->able != 1)
            return false;
        ans.push_back(cur->v);
        if (cur->l)
            q.push(cur->l);
        if (cur->r)
            q.push(cur->r);
    }
    return true;
}

void showAns()
{
    for (int i = 0; i != ans.size(); ++i)
        (TEST ? ofs : cout) << ans.at(i) << (i == ans.size() - 1 ? "" : " ");
    (TEST ? ofs : cout) << '\n';
}

int main()
{

    if (TEST)
    {
        ofs.open("/home/lixiaoqi/Documents/Code/C++/1.txt");
        if (!ofs.is_open())
            throw runtime_error("FILE NOT OPEN!");
    }

    while (cin.peek() != EOF)
    {
        root = new Node;
        while (readInput())
            continue;
        if (bfs())
            showAns();
        else
            (TEST ? ofs : cout) << "not complete\n";

        ans.clear();
        removeTree(root);
        cin.ignore(1024, '\n');
    }
    return 0;
}

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-10-26 12:25:59  更:2021-10-26 12:26:44 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 4:41:51-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码