UVa 112 树求和
题意:给定一个数字,以及一个描写叙述树的字符序列,问存不存在一条从根到某叶子结点的路径使得其和等于那个数。
难点在于怎样处理字符序列。由于字符间可能有空格、换行等。
思路:本来想着用scanf的(后发现scanf貌似不能做)。感觉太麻烦。想看网上有没有处理比較好的,一搜全是用C++的cin流的~ 还是自己用C写了一下。
用的getchar()。getchar()主要就是比較繁琐。须要一个一个字符比較,记得刚開始做字符串题目时比較喜欢用getchar(),有的用scanf即可的自己也喜欢用getchar();好久没用了,写之前认为有些麻烦。
。纠结了一下~ 还是不要嫌麻烦啊。
。
这里还是避免了动态内存分配及释放这个易出错的东西,用一个先申请了的大Node数组anode,以及cnt记录已使用的anode的最大下标。
相同,当中用栈来匹配时,入栈和出栈的都是对应结点在anode数组中的下标值。(已经用这种方法连续做几道题了,走火入魔了~)
处理树的录入的情况是,每读一个字符分三种情况:左括号、数字、右括号,及其它忽略。
读入左括号时,若之前是在读数字(dsz为1)。则数字结束。转为int型。初始化一个Node结点。在结点入栈前,若栈非空。则该结点是栈顶元素的左或右孩子(通过结构体的lv域推断左孩子是否已赋值)。
读入数字时,非常easy,主要注意负数的情况。读入右括号时,假设上一次是读的左括号(zkh为1),则说明读的是一个空括号,这种情况下假设栈为空。则是读入了一个空树的特殊情形,若栈非空,则将栈顶元素的左或右孩子置为空,相同通过lv域来推断左右;假设读到的不是空括号,则相应栈顶元素的左右孩子均已赋值。出栈。
这样就可以建树。
只是能够发现和值在建树过程中就可以计算,仅仅要维护一个值。它是栈中元素的值之和就可以。(程序中的he值)每到叶子结点时,通过与给定的值推断。另外还需注意的就是如何跳出读取树描写叙述符字节序列的这个while循环。
这里用栈为空的时候。只是有几个特殊情况又须要fg变量进行标记,比方第一个为空格字符top本来就为0但不应跳出,比方读到空树时尽管没有数字入栈过但应该要跳出了所以置fg为1。
注意:值可为负数。(这个网搜的时候看别人提到,不知道自己会不会注意到)
本地调了几次,一次就AC了还是不错的。没有什么大错误,注意到一个数字读完后把计数置0即可了。UVa 365名还能够
Code:
#include<stdio.h>
#include<ctype.h>
#include<stdlib.h>
#define MAXN 1000 typedef struct node
{
int data;
int left,right;
bool lv;//左孩子是否已赋值
bool lnull;//左孩子是否为空
}Node; Node anode[MAXN];
int cnt=0;//已经用的Node的最大下标。 位置0不用,代表空节点。 int main()
{
int sum=0;
while(scanf("%d",&sum)==1)
{//读一行
char c;
bool zkh=0;
char num[15]; int x=0;
bool dsz=0;
int stack[MAXN]; int top=0;//top始终指向栈顶元素,位置0不用,代表空栈
int he=0;//树的和值,当前栈内元素的和值。
bool flag=0;
cnt=0;
bool fg=0;
while((c=getchar()))
{//读树形式
if(c=='(')
{
if(dsz)
{
num[x]='\0';
x=0; //注意这里一个数字输入结束后需置零下标位
int nmb=atoi(num);
//构造新结点
anode[++cnt].data=nmb;
anode[cnt].left=anode[cnt].right=0;
anode[cnt].lv=0;
anode[cnt].lnull=0;
//入栈
fg=1;//证明曾有数字入栈过
if(top)
{//若栈非空,则当前元素是栈顶元素的左或右孩子
if(anode[stack[top]].lv==0) {anode[stack[top]].left=cnt; anode[stack[top]].lv=1;}
else anode[stack[top]].right=cnt;
}
he=he+nmb;
stack[++top]=cnt;
}
dsz=0;
zkh=1;
}
else if(c=='-'||isdigit(c))
{
num[x++]=c;
dsz=1;
zkh=0;
}
else if(c==')')
{
if(zkh)//读到空括号()
{
if(top)
{
if(anode[stack[top]].lv==0) {anode[stack[top]].left=0; anode[stack[top]].lv=1; anode[stack[top]].lnull=1;}
else {anode[stack[top]].right=0; if(anode[stack[top]].lnull&&he==sum) {flag=1; } }//若左右孩子均为空,则为叶子结点,则可比較和值。 这里flag=1后还是不要break比較好,由于匹配栈到空时才退出循环,不然不好推断后面的输入字符到什么时候结束,不能用换行推断。
}
else//读到空括号()且栈为空,则是空树。 并把fg置1可跳出循环
{ flag=0; fg=1;}
}
else
{//出栈
he=he-anode[stack[top]].data;
top--;
}
dsz=0;
zkh=0;
}
if(fg&&(top==0)) break;
}//while
printf("%s\n",flag?"yes":"no");
}
return 0;
}
UVa 112 树求和的更多相关文章
- UVa 112 - Tree Summing(树的各路径求和,递归)
题目来源:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=3&pa ...
- noip模拟8[星际旅行·砍树·超级树·求和]
也不能算考得好,虽然这次A了一道题,但主要是那道题太简单了,没啥成就感,而且有好多人都A掉了 除了那一道,其他的加起来一共拿了25pts,这我能咋办,无奈的去改题 整场考试的状态并不是很好啊,不知道是 ...
- 6.17考试总结(NOIP模拟8)[星际旅行·砍树·超级树·求和]
6.17考试总结(NOIP模拟8) 背景 考得不咋样,有一个非常遗憾的地方:最后一题少取膜了,\(100pts->40pts\),改了这么多年的错还是头一回看见以下的情景... T1星际旅行 前 ...
- UVa 10410树重建
https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- uva 12086 树状数组
树状数组 #include <cstdio> #include <cstdlib> #include <cmath> #include <map> #i ...
- UVa 1220 (树的最大独立集) Party at Hali-Bula
题意: 有一棵树,选出尽可能多的节点是的两两节点不相邻,即每个节点和他的子节点只能选一个.求符合方案的最大节点数,并最优方案判断是否唯一. 分析: d(u, 0)表示以u为根的子树中,不选u节点能得到 ...
- UVa 112 Tree Summing
题意: 计算从根到叶节点的累加值,看看是否等于指定值.是输出yes,否则no.注意叶节点判断条件是没有左右子节点. 思路: 建树过程中计算根到叶节点的sum. 注意: cin读取失败后要调用clear ...
- Uva 122 树的层次遍历 Trees on the level lrj白书 p149
是否可以把树上结点的编号,然后把二叉树存储在数组中呢?很遗憾如果结点在一条链上,那将是2^256个结点 所以需要采用动态结构 首先要读取结点,建立二叉树addnode()+read_input()承担 ...
- UVa 11695 树的直径 Flight Planning
题意: 给出一棵树,删除一条边再添加一条边,求新树的最短的直径. 分析: 因为n比较小(n ≤ 2500),所以可以枚举删除的边,分裂成两棵树,然后有这么一个结论: 合并两棵树后得到的新树的最短直径为 ...
随机推荐
- 获取鼠标经过处的标签的标签名和id
<script> var el = window.document.body; // 声明一个变量,默认值为body window.document.body.onmouseover = ...
- LightOJ-1336 Sigma Function 唯一分解定理 巧妙使用sqrt()等算数目
题目链接:https://cn.vjudge.net/problem/LightOJ-1336 题意 给出一个区间[1, n],求区间内所有数中因数之和为偶数的数目 思路 第二次写这个题 首先想到唯一 ...
- ztree实现根节点单击事件,显示节点信息
这段时间在维护公司的项目,去年做的项目里面有ztree树的例子,想起之前还没有开始写博客,一些知识点也无从找起,要新加一个右击节点事件,折腾了半天,其中也包含了一些知识点,稍稍做了一些demo. zT ...
- 题解 P3834 【【模板】可持久化线段树 1(主席树)】
可持久化线段树的前置知识是权值线段树,但是你不学也没有太大的关系因为思想不是很难理解. 可持久化线段树支持历史记录查询,这是它赖以解题的方法. 在本题中思路是建立n颗线段树,然后对于每次询问,考虑其中 ...
- 题解 LNOI2014 LCA
题目:传送门 这道题根本不用lca,也没有部分分... 考虑求两个点xy的lca的深度. 我们将x到树根所有点的值都加1,然后查询y到根的和,其实就是lca的深度. 所以本题离线一下上树剖乱搞就可以了 ...
- mysql死锁-查询锁表进程-分析锁表原因
查询锁表进程: 1.查询是否锁表 show OPEN TABLES where In_use > 0; 2.查询进程 show processlist 查询到相对应的进程===然 ...
- XML快速注释
eclipse中编辑java或C/C++,python文件时,注释的快捷键均为 "CTRL + / ",编辑xml文件时,该快捷键无效. eclipse XML 注释:CTRL + ...
- 【Codeforces】512C Fox and Dinner
[解析]欧拉筛法,奇偶分析.建二分图,网络流 [Analysis] http://blog.csdn.net/qq574857122/article/details/43453087. 所谓的连通块就 ...
- 使用IR2101半桥驱动电机的案例
作为一个电机驱动开发方面的菜鸟,近日研究了一下通过MOS管对整流后的电源斩波用以驱动直流电机进行调速的方案. 在驱动的过程中,遇到了很多问题,当然也有很多的收获. 写下来以供自己将来查阅,也为其他菜鸟 ...
- 移动端页面弹出对话框效果Demo
核心思路:设置一个隐藏的(display:none;).背景偏暗的div及其子div作为对话框.当点击某处时,将此div设置为显示. 核心代码例如以下(部分js代码用于动态调整div内容的行高.这部分 ...