PAT甲级1130 Infix Expression:[C++题解]中缀表达式、二叉树中序遍历、dfs

本文主要是介绍PAT甲级1130 Infix Expression:[C++题解]中缀表达式、二叉树中序遍历、dfs,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 题目分析
    • 题目链接

题目分析

在这里插入图片描述
在这里插入图片描述
来源:acwing

分析:本题是借助中缀表达式这个背景,考察二叉树的中序遍历。本题需要注意的地方是加括号。 左子树和右子树无脑加括号,只要不是叶结点。
所以写dfs的时候需要特判叶结点,叶结点不加括号。

  • 这里直接用两个左右儿子数组存树l[N],r[N]。只要找到根结点,直接从根开始遍历即可。

ac代码

#include<bits/stdc++.h>
using namespace std;
const int N =30;int l[N],r[N]; 
string w[N]; //结点的值bool st[N]; //求根结点,st[i]有父节点记为true
bool is_leaf[N]; //is_leaf[i]  =true表示 i是叶结点//二叉树的深度优先遍历
//返回表达式的值
string dfs(int u){string left ,right; //左儿子,右儿子//左儿子存在if(l[u] != -1){left = dfs(l[u]);if(!is_leaf[l[u]]) left = "(" + left + ")";}//右儿子存在if(r[u] != -1){right = dfs(r[u]);if(!is_leaf[r[u]]) right = "(" +right +")";}//结点u左儿子不存在,右儿子不存在时才会到这一步//所以u是叶结点,return left + w[u] +right;}int main(){int n;cin >> n;for(int i =1; i<= n; i++){cin >> w[i] >> l[i] >> r[i];if(l[i] != -1) st[l[i]] =true;if(r[i] != -1) st[r[i]] = true;if(l[i] == -1 && r[i] == -1) is_leaf[i] =true;}int root =0;//没有父节点的结点是根结点for(int i=1; i<=n; i++)if(!st[i])  root = i;cout<<dfs(root)<<endl;}

在这里插入图片描述

题目链接

PAT甲级1130 Infix Expression
https://www.acwing.com/problem/content/1625/

这篇关于PAT甲级1130 Infix Expression:[C++题解]中缀表达式、二叉树中序遍历、dfs的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C/C++错误信息处理的常见方法及函数

《C/C++错误信息处理的常见方法及函数》C/C++是两种广泛使用的编程语言,特别是在系统编程、嵌入式开发以及高性能计算领域,:本文主要介绍C/C++错误信息处理的常见方法及函数,文中通过代码介绍... 目录前言1. errno 和 perror()示例:2. strerror()示例:3. perror(

C++变换迭代器使用方法小结

《C++变换迭代器使用方法小结》本文主要介绍了C++变换迭代器使用方法小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1、源码2、代码解析代码解析:transform_iterator1. transform_iterat

详解C++中类的大小决定因数

《详解C++中类的大小决定因数》类的大小受多个因素影响,主要包括成员变量、对齐方式、继承关系、虚函数表等,下面就来介绍一下,具有一定的参考价值,感兴趣的可以了解一下... 目录1. 非静态数据成员示例:2. 数据对齐(Padding)示例:3. 虚函数(vtable 指针)示例:4. 继承普通继承虚继承5.

C++中std::distance使用方法示例

《C++中std::distance使用方法示例》std::distance是C++标准库中的一个函数,用于计算两个迭代器之间的距离,本文主要介绍了C++中std::distance使用方法示例,具... 目录语法使用方式解释示例输出:其他说明:总结std::distance&n编程bsp;是 C++ 标准

C++ 中的 if-constexpr语法和作用

《C++中的if-constexpr语法和作用》if-constexpr语法是C++17引入的新语法特性,也被称为常量if表达式或静态if(staticif),:本文主要介绍C++中的if-c... 目录1 if-constexpr 语法1.1 基本语法1.2 扩展说明1.2.1 条件表达式1.2.2 fa

SpringBoot @Scheduled Cron表达式使用方式

《SpringBoot@ScheduledCron表达式使用方式》:本文主要介绍SpringBoot@ScheduledCron表达式使用方式,具有很好的参考价值,希望对大家有所帮助,如有... 目录Cron 表达式详解1. 表达式格式‌2. 特殊字符解析3. 常用示例‌4. 重点规则5. 动态与复杂场景‌

C++中::SHCreateDirectoryEx函数使用方法

《C++中::SHCreateDirectoryEx函数使用方法》::SHCreateDirectoryEx用于创建多级目录,类似于mkdir-p命令,本文主要介绍了C++中::SHCreateDir... 目录1. 函数原型与依赖项2. 基本使用示例示例 1:创建单层目录示例 2:创建多级目录3. 关键注

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

C++字符串提取和分割的多种方法

《C++字符串提取和分割的多种方法》在C++编程中,字符串处理是一个常见的任务,尤其是在需要从字符串中提取特定数据时,本文将详细探讨如何使用C++标准库中的工具来提取和分割字符串,并分析不同方法的适用... 目录1. 字符串提取的基本方法1.1 使用 std::istringstream 和 >> 操作符示