例题6-10 The Falling Leaves,UVA699
这道题我的思路是先通过递归构建树,然后进行遍历将位置和保存在map映射中,最后按顺序输出map集合中的值。
至于如何遍历,我是依次尝试了宽度优先遍历和深度优先遍历,当然这都是可以的。不过期间写错了很多次。在此总结以下在这道题目中犯得错误(逻辑错误):
- 同一树,根节点地址不变,却多次使用
- 同一映射,不经清空却多次添加
- 遍历时在队列和栈中添加进的节点不是当前节点(即写错节点名称)
- 栈溢出导致结果出错
- 对一个节点分配内存只能在同一函数中进行 //否则需要添加指针引用(*指针也需要引用)
。。。。
以下附上我的AC代码:
#include <cstdio>
#include <queue>
#include <iostream>
#include <vector>
#include <map>
#include <stack>
using namespace std;
struct Node{
Node *left;
Node *right;
int v;
int k;
Node():left(NULL),right(NULL){}
};
map<int,int> m;
void remove_tree(Node* u){
if(u==NULL)return ;
remove_tree(u->left);
remove_tree(u->right);
delete u;
}
int solve(Node *& u){//特别注意这一段
int v;
scanf("%d", &v);
if(v == -){ u->v=;return ;}
else {
u->left = new Node();
u->right = new Node();
u->v = v;
solve(u->left);//左子树
solve(u->right);//右子树
}
return ;
}
queue<Node*> q;
//宽度优先遍历
void bfs(Node * u){
u->k=;
q.push(u);
while(!q.empty()){
Node * node =q.front();
q.pop();
if(node->v)m[node->k] = m[node->k]+(node->v);
if(node->left!=NULL&&node->left->v){node->left->k = (node->k)-;; q.push(node->left);}
if(node->right!=NULL&&node->right->v){node->right->k = (node->k )+ ; q.push(node->right);}
} }
stack<Node*> s;
//深度优先遍历:stl栈板
void dfs1(Node* u,int k){ u->k=k;
s.push(u);
while(!s.empty()){
Node *node=s.top();
s.pop();
if(node->left!=NULL&&node->left->v){node->left->k=(node->k)-;s.push(node->left);}
if(node->v)m[node->k] = m[node->k]+(node->v); if(node->right!=NULL&&node->right->v){node->right->k=(node->k)+;s.push(node->right);} }
}
//深度优先遍历:递归版
void dfs(Node* u,int k){
// printf("%d ,%d\n",u->v,k);
if(u->v)m[k] = m[k]+(u->v);
if(u->left!=NULL&&u->left->v)dfs(u->left,k-);
if(u->right!=NULL&&u->right->v)dfs(u->right,k+);
}
int main(){
#ifdef DEBUG
freopen("6.10.in","r",stdin);
freopen("6.10.out","w",stdout);
#endif
int n = ,r;
Node *root=new Node() ;
while((r=solve(root))){
printf("Case %d:\n",++n);
bfs(root); //*****************注意在一个树使用完毕之后一定要删除它
remove_tree(root);
root=new Node();//注意要重新建一个根节点 int first=;
for(map<int,int>::iterator it = m.begin(); it!= m.end(); ++it){
if(!first)cout<<" ";else first=;
cout <<it->second;
}
m.clear();//使用完之后要清空 printf("\n");
if(r)printf("\n");
else break;
}
return ;
}
例题6-10 The Falling Leaves,UVA699的更多相关文章
- UVa699 The Falling Leaves
// UVa699 The Falling Leaves // 题意:给一棵二叉树,每个节点都有一个水平位置:左儿子在它左边1个单位,右儿子在右边1个单位.从左向右输出每个水平位置的所有结点的权值 ...
- 【数据结构】The Falling Leaves(6-10)
[UVA699]The Falling Leaves 算法入门经典第6章例题6-10(P159) 题目大意:有一颗二叉树,求水平位置的和. 试题分析:乱搞就可以过,将树根节点的pos记为0,向左-1, ...
- UVA 699 The Falling Leaves (二叉树水题)
本文纯属原创.转载请注明出处,谢谢. http://blog.csdn.net/zip_fan. Description Each year, fall in the North Central re ...
- H - The Falling Leaves
Description Each year, fall in the North Central region is accompanied by the brilliant colors of th ...
- UVA - 699The Falling Leaves(递归先序二叉树)
The Falling Leaves Time Limit: 3000MS Memory Limit: Unknown 64bit IO Format: %lld & %llu Sub ...
- POJ 1577 Falling Leaves 二叉搜索树
HDU 3791 Falling Leaves 二叉搜索树 Figure 1Figure 1 shows a graphical representation of a binary tree of ...
- UVA.699 The Falling Leaves (二叉树 思维题)
UVA.699 The Falling Leaves (二叉树 思维题) 题意分析 理解题意花了好半天,其实就是求建完树后再一条竖线上的所有节点的权值之和,如果按照普通的建树然后在计算的方法,是不方便 ...
- The Falling Leaves(建树方法)
uva 699 紫书P159 Each year, fall in the North Central region is accompanied by the brilliant colors of ...
- UVa 699 The Falling Leaves(递归建树)
UVa 699 The Falling Leaves(递归建树) 假设一棵二叉树也会落叶 而且叶子只会垂直下落 每个节点保存的值为那个节点上的叶子数 求所有叶子全部下落后 地面从左到右每 ...
- UVa 699 The Falling Leaves (树水题)
Each year, fall in the North Central region is accompanied by the brilliant colors of the leaves on ...
随机推荐
- 使用JavaScript实现新闻滚动效果
最近要实现一个滚动新闻效果,在网上查了一些资料,发现基本的实现方法有两种: 使用Marquee标签.这个标签的使用我已经转载了一篇比较详细的文章,这个标签的优点是便于使用,缺点是人们已经逐渐不适用它了 ...
- Oracle自增列
一.介绍: 在设计数据库时,有时候希望表的某一列为自增列,例如编号,本文就介绍如何在oracle数据库中实现自增列,需要两个步骤: 1)构建序列(sequence) 在oracle中sequence就 ...
- Wireshark的时间格式设置
默认是自捕获开始经历的秒数,如下图: 要调整的设置步骤: step1.打开wireshark step2.选择view->Time Display Fommat step3.选择你所需要的时间格 ...
- 开一个帖子,等有时间了写写如何用shapelib创建点线面等shp图层
开一个帖子,等有时间了写写如何用shapelib创建点线面等shp图层 C#操作shapelib的实例 http://files.cnblogs.com/yuxuetaoxp/Shapelib--D ...
- gitlab和Django实现push自动更新
1.设置webhook gitlab->setting->webhook:http://121.143.191.166:7000?token=23028-b396-12e5-9912-ba ...
- JavaScript对象的创建之构造函数
通过构造函数的方式创建和基于工厂的创建类似,最大的区别就是函数的名称就是类的名称,按照java的约定,第一个字母大写. 使用构造函数创建对象时,在函数内部是通过this关键字来完成属性的定义. fun ...
- (转)直接拿来用!最火的iOS开源项目(一)
1. AFNetworking 在众多iOS开源项目中,AFNetworking可以称得上是最受开发者欢迎的库项目.AFNetworking是一个轻量级的iOS.Mac OS X网络通信类库,现在是G ...
- JAVA集合学习
JAVA中有几种常用的集合类.分别是List,Set,Map等 提示:Eclipse中自动导入包的快捷键 Ctrl+Shift+O 一.List类 父接口:该类是Collection集合接口的子接口 ...
- android EditText 只允许输入指定字符
实现只允许只入数字和字符 方法一:在XML文件中实现布局如下: <EditText android:layout_width="match_parent" android:l ...
- iptable怎么用?
iptables -A FORWARD -s 10.0.0.0/8 -p tcp --dport 80 -j DROP [拒绝转发来自10.0.0.0/8网段,目的端口是80的数据包]