A1130 | 中缀表达式、查找根节点
代码:
#include <stdio.h>
#include <memory.h>
#include <math.h>
#include <string>
#include <vector>
#include <set>
#include <stack>
#include <queue>
#include <algorithm>
#include <map> #define I scanf
#define OL puts
#define O printf
#define F(a,b,c) for(a=b;a<c;a++)
#define FF(a,b) for(a=0;a<b;a++)
#define FG(a,b) for(a=b-1;a>=0;a--)
#define LEN 10000
#define MAX 0x06FFFFFF
#define V vector<int> using namespace std; typedef struct inputInfo{
string d;int l,r;
}inputInfo; typedef struct Node{
string d;struct Node * l=NULL;struct Node * r=NULL;
Node(){}
Node(string D){d=D;}
}Node; inputInfo infoArr[];
Node *nodes[];
int used[];
Node * insert_node(int index);
void inOrder(Node* node);
Node * root;
int cnt=; int main() {
freopen("d:/input/A1130/1.txt","r",stdin);
int N,i;
scanf("%d",&N);
F(i,,N+){
char buffer[];
scanf("%s %d %d",buffer,&infoArr[i].l,&infoArr[i].r);
infoArr[i].d=buffer;
}
F(i,,N+){
if(!used[i])insert_node(i);
if(cnt>=N) break;
}
// printf("%d %d\n",cnt,i);
root=nodes[i];
inOrder(root->l);
printf("%s",root->d.c_str());
inOrder(root->r);
return ;
} Node * insert_node(int index){
used[index]=;
cnt++;
inputInfo info=infoArr[index];
Node *node=new Node(info.d); int l=info.l,r=info.r;
if(l>)
if(used[l]){
node->l=(nodes[l]);
}else{
node->l=insert_node(l);
}
if(r>)
if(used[r]){
node->r=(nodes[r]);
}else{
node->r=insert_node(r);
}
nodes[index]=node; return node;
} void inOrder(Node* node){
if(node){
bool haveK=(node->l||node->r)?:;
if(haveK) O("(");
inOrder(node->l);
printf("%s",node->d.c_str());
inOrder(node->r);
if(haveK) O(")");
}
}
主要的点有两个。首先是中缀表达式:
void inOrder(Node* node){
    if(node){
        bool haveK=(node->l||node->r)?:;
        if(haveK) O("(");
        inOrder(node->l);
        printf("%s",node->d.c_str());
        inOrder(node->r);
        if(haveK) O(")");
    }
}
inOrder(root->l);
printf("%s",root->d.c_str());
inOrder(root->r);
对中序遍历稍加修改,就可以得到像这样的中缀表达式:(a+b)*(c*(-d))
其次是录入输入信息后怎样不浪费时间,巧妙的找到根节点是哪一行记录。这里我们用nodes数组记录树形结点,用used数组记录是否访问过,用cnt记录形成结点的个数,然后递归调用insert_node,就可以及时找到根节点的记录。
需要进步的点:做题速度太慢。
A1130 | 中缀表达式、查找根节点的更多相关文章
- 【转】oracle CONNECT BY PRIOR叶子节点查找根节点
		
SELECT TRANS_ID FROM TRANS_INST WHERE connect_by_isleaf=1 START WITH TRANS_ID =480242 CONNECT BY PRI ...
 - C#操作XML学习之创建XML文件的同时新建根节点和子节点(多级子节点)
		
最近工作中遇到一个问题,要求创建一个XML文件,在创建的时候要初始化该XML文档,同时该文档打开后是XML形式,但是后缀名不是.在网上找了好些资料没找到,只能自己试着弄了一下,没想到成功了,把它记下来 ...
 - 数据结构(3) 第三天 栈的应用:就近匹配/中缀表达式转后缀表达式 、树/二叉树的概念、二叉树的递归与非递归遍历(DLR LDR LRD)、递归求叶子节点数目/二叉树高度/二叉树拷贝和释放
		
01 上节课回顾 受限的线性表 栈和队列的链式存储其实就是链表 但是不能任意操作 所以叫受限的线性表 02 栈的应用_就近匹配 案例1就近匹配: #include <stdio.h> in ...
 - 通过不断迭代,编写<通过中缀表达式,构造表达式树>的代码
		
今天要练习的算法是通过中缀表达式生成表达式树.中缀.前缀.后缀表达式的概念就不赘述了,学习链接:中缀.前缀.后缀表达式. 参考代码学习链接:表达式树—中缀表达式转换成后缀表达式(一). [迭代 ①]: ...
 - hdu 2545(并查集求节点到根节点的距离)
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2545 思路:dist[u]表示节点u到根节点的距离,然后在查找的时候更新即可,最后判断dist[u], ...
 - C#用xpath查找某节点
		
C#用xpath查找某节点 从根节点一直下来的相对路径才能确定Xpath的写法. /root/<节点1>/<节点2>//<@属性> Xpath是功能很强大的,但是也 ...
 - 二叉树各种相关操作(建立二叉树、前序、中序、后序、求二叉树的深度、查找二叉树节点,层次遍历二叉树等)(C语言版)
		
将二叉树相关的操作集中在一个实例里,有助于理解有关二叉树的相关操作: 1.定义树的结构体: typedef struct TreeNode{ int data; struct TreeNode *le ...
 - 用TinyXml做XML解析示例 TinyXml查找唯一节点及修改节点操作
		
// 读者对象:对TinyXml有一定了解的人.本文是对TinyXml工具的一些知识点的理解. // 1 TinyXml中对TiXmlNode进行了分类,是用一个枚举进行描述的. // enum No ...
 - MySQL InnoDB primary key根节点常驻内存
		
mysql的InnoDB存储引擎在设计时是将根节点常驻内存的,也就是说查找某一键值的行记录时最多只需要1~3次磁盘I/O操作.
 
随机推荐
- Logstash配置文件修改自动加载和指定目录进行启动
			
检查配置并启动Logstash,修改后自动加载 指定配置文件目录并启动Logstash
 - c#创建windows服务(代码方式安装、启动、停止、卸载服务)
			
转载于:https://www.cnblogs.com/mq0036/p/7875864.html 一.开发环境 操作系统:Windows 10 X64 开发环境:VS2015 编程语言:C# .NE ...
 - WinForm的TextBox限制只能输入数字并且屏蔽默认右键菜单
			
基于Window消息实现 class TextBoxExt:TextBox { private const int WM_RBUTTONDOWN = 0x0204; private const int ...
 - Java自学-JDK环境变量配置
			
JDK环境变量配置 分下载,配置,验证三个步骤进行JDK环境变量配置. 步骤 1 : 首先看配置成功后的效果 点WIN键->运行(或者使用win+r) 输入cmd命令 输入java -versi ...
 - this、对象原型
			
this和对象原型 第一章 关于this 1.1 为什么要用this this 提供了一种更优雅的方式来隐式"传递"一个对象引用,因此可以将 API 设计 得更加简洁并且易于复用. ...
 - Java学习之:Spring的扩展配置
			
1.在配置文件applicationContext.xml中,引入相关的配置文件方式: 2.使用Jndi数据源的方式改造配置文件applicationContext.xml: 3.注释配置文件appl ...
 - Active Directory渗透测试典型案例
			
0x01 前言 我有几个客户在渗透测试之前来找我,说他们的系统安全做得非常好,因为他们的漏洞扫描显示没有严重的漏洞并且已准备好进行安全测试,这使我在15分钟内利用AD中的错误配置获得了域管理员权限. ...
 - 阿里云ECS使用vnc远程连接(Ubuntu + CentOS)
			
阿里云ECS使用vnc远程连接https://blog.csdn.net/m0_37264397/article/details/78271896 在Linux实例上自动安装并运行VNC Server ...
 - (十二)Kubernetes 认证、授权与准入控制
			
访问控制概述 API Server作为Kubernetes集群系统的网关,是访问和管理资源对象的唯一入口:包括kube-controller-manager.kube-scheduler.kubele ...
 - Codeforces C Match Points(二分贪心)
			
题目描述: Match Points time limit per test 2 seconds memory limit per test 256 mega bytes input standard ...