个人练习-PAT甲级-1099 Build A Binary Search Tree

2023-10-17 22:18

本文主要是介绍个人练习-PAT甲级-1099 Build A Binary Search Tree,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接https://pintia.cn/problem-sets/994805342720868352/problems/994805367987355648

题目大意:给出一颗BST的结构,以及一串数字,可以得到唯一的二叉搜索树。求这棵BST的层序遍历。

复习了下中序遍历和层序遍历。因为BST的中序遍历结果就是从小到大排序,所以首先可以将这串数字arr[]排序(即得到中序遍历的结果),然后对树进行中序遍历,依次插入arr[]的元素的值。注意如果子节点为空那么跳过即可。cnt记录下一个要被插入树中的arr[]元素的下标。

void inOrder(int idx) {if (tree[idx].left_idx != -1)inOrder(tree[idx].left_idx);tree[idx].val = arr[cnt++];if (tree[idx].right_idx != -1)inOrder(tree[idx].right_idx);
}

层序遍历,要用到一个队列。每次pop()队首元素前,先把其所有子节点都从左到右push()进队列,然后将队首元素pop()并输出。注意此时cnt的含义变为【已经pop()了多少个结果】,在第二个及以后的输出时要加一个空格。

void levelOrider() {q.push(tree[0]);while (q.empty() == false) {if (q.front().left_idx != -1)q.push(tree[q.front().left_idx]);if (q.front().right_idx != -1)q.push(tree[q.front().right_idx]);if (cnt == 0) {printf("%d", q.front().val);cnt++;}else {printf(" %d", q.front().val);}q.pop();}
}

总结:主要还是树的遍历要记牢。

完整代码

#include <iostream>
#include <stdio.h>
#include <math.h>
#include <vector>
#include <algorithm>
#include <queue>
#include <map>using namespace std;class Node {
public:int val;int left_idx, right_idx;
};vector<int> arr;
vector<Node> tree;
queue<Node> q;
int cnt;void inOrder(int idx) {if (tree[idx].left_idx != -1)inOrder(tree[idx].left_idx);tree[idx].val = arr[cnt++];if (tree[idx].right_idx != -1)inOrder(tree[idx].right_idx);
}void levelOrider() {q.push(tree[0]);while (q.empty() == false) {if (q.front().left_idx != -1)q.push(tree[q.front().left_idx]);if (q.front().right_idx != -1)q.push(tree[q.front().right_idx]);if (cnt == 0) {printf("%d", q.front().val);cnt++;}else {printf(" %d", q.front().val);}q.pop();}
}int main() {int N;scanf("%d", &N);tree.resize(N);for (int i = 0; i < N; i++) {scanf("%d %d", &tree[i].left_idx, &tree[i].right_idx);}arr.resize(N);for (int i = 0; i < N; i++)scanf("%d", &arr[i]);sort(arr.begin(), arr.end());inOrder(0);cnt = 0;levelOrider();return 0;
}

这篇关于个人练习-PAT甲级-1099 Build A Binary Search Tree的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/228292

相关文章

uva 575 Skew Binary(位运算)

求第一个以(2^(k+1)-1)为进制的数。 数据不大,可以直接搞。 代码: #include <stdio.h>#include <string.h>const int maxn = 100 + 5;int main(){char num[maxn];while (scanf("%s", num) == 1){if (num[0] == '0')break;int len =

MCU7.keil中build产生的hex文件解读

1.hex文件大致解读 闲来无事,查看了MCU6.用keil新建项目的hex文件 用FlexHex打开 给我的第一印象是:经过软件的解释之后,发现这些数据排列地十分整齐 :02000F0080FE71:03000000020003F8:0C000300787FE4F6D8FD75810702000F3D:00000001FF 把解释后的数据当作十六进制来观察 1.每一行数据

RabbitMQ练习(AMQP 0-9-1 Overview)

1、What is AMQP 0-9-1 AMQP 0-9-1(高级消息队列协议)是一种网络协议,它允许遵从该协议的客户端(Publisher或者Consumer)应用程序与遵从该协议的消息中间件代理(Broker,如RabbitMQ)进行通信。 AMQP 0-9-1模型的核心概念包括消息发布者(producers/publisher)、消息(messages)、交换机(exchanges)、

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close

HomeBank:开源免费的个人财务管理软件

在个人财务管理领域,找到一个既免费又开源的解决方案并非易事。HomeBank&nbsp;正是这样一个项目,它不仅提供了强大的功能,还拥有一个活跃的社区,不断推动其发展和完善。 开源免费:HomeBank 是一个完全开源的项目,用户可以自由地使用、修改和分发。用户友好的界面:提供直观的图形用户界面,使得非技术用户也能轻松上手。数据导入支持:支持从 Quicken、Microsoft Money

【Rust练习】12.枚举

练习题来自:https://practice-zh.course.rs/compound-types/enum.html 1 // 修复错误enum Number {Zero,One,Two,}enum Number1 {Zero = 0,One,Two,}// C语言风格的枚举定义enum Number2 {Zero = 0.0,One = 1.0,Two = 2.0,}fn m

MySql 事务练习

事务(transaction) -- 事务 transaction-- 事务是一组操作的集合,是一个不可分割的工作单位,事务会将所有的操作作为一个整体一起向系统提交或撤销请求-- 事务的操作要么同时成功,要么同时失败-- MySql的事务默认是自动提交的,当执行一个DML语句,MySql会立即自动隐式提交事务-- 常见案例:银行转账-- 逻辑:A给B转账1000:1.查询

html css jquery选项卡 代码练习小项目

在学习 html 和 css jquery 结合使用的时候 做好是能尝试做一些简单的小功能,来提高自己的 逻辑能力,熟悉代码的编写语法 下面分享一段代码 使用html css jquery选项卡 代码练习 <div class="box"><dl class="tab"><dd class="active">手机</dd><dd>家电</dd><dd>服装</dd><dd>数码</dd><dd

分布式系统的个人理解小结

分布式系统:分的微小服务,以小而独立的业务为单位,形成子系统。 然后分布式系统中需要有统一的调用,形成大的聚合服务。 同时,微服务群,需要有交流(通讯,注册中心,同步,异步),有管理(监控,调度)。 对外服务,需要有控制的对外开发,安全网关。

Java IO 操作——个人理解

之前一直Java的IO操作一知半解。今天看到一个便文章觉得很有道理( 原文章),记录一下。 首先,理解Java的IO操作到底操作的什么内容,过程又是怎么样子。          数据来源的操作: 来源有文件,网络数据。使用File类和Sockets等。这里操作的是数据本身,1,0结构。    File file = new File("path");   字