思路:当时学长讲了之后,似乎有点思路----------就是倒着建一个  二叉搜索树

代码1:超时

详见超时原因

#include<iostream>
#include<cstring>
#include<stdio.h>
using namespace std; char c[100][100];
struct node
{
char c;
node *lchild;
node *rchild;
}; void f(node *p)//前序遍历输出,用递归
{
printf("%c",p->c);
if(p->lchild!=NULL)
f(p->lchild);
if(p->rchild!=NULL)
f(p->rchild);
} int main()
{
int i;
int j;
int exit;
exit=0;
while(1)
{
memset(c,'\0',sizeof(c));
i=0;
while(1)
{
scanf("%s",c[i]);
if(c[i][0]=='*'||c[i][0]=='$')
{
if(c[i][0]=='$')
exit=1;
break;
}
i++;
}
i--;
node *p=new node;
p->c=c[i][0];
p->lchild=NULL;
p->rchild=NULL;
i--;
node *p2;
while(1)//遍历i
{
j=0;
while(1)//遍历j
{
p2=p;
node *p3=new node;//存储字母节点
p3->c=c[i][j];
p3->lchild=NULL;
p3->rchild=NULL;
while(1)//把字母挂到树中
{
if(p3->c < p2->c)
{
if(p2->lchild==NULL)
{
p2->lchild=p3;
break;
}
else if(p2->lchild!=NULL)//超时原因
p2=p2->lchild;
}
else if(p3->c > p2->c)//超时原因
{
if(p2->rchild==NULL)
{
p2->rchild=p3;
break;
}
else if(p2->rchild!=NULL)//超时原因,这三处的 else if() 判断多余,应直接写成else
p2=p2->rchild;
}
}
j++;
if(c[i][j]=='\0')
break;
}
i--;
if(i==-1)//修正超时原因后,此处会造成 runtime error,因为i为 -1时 也会 进入此while循环,数组越界
break;
}
f(p);
printf("\n");
if(exit==1)
break;
}
return 0;
}

修正代码:

1.

当时也是看了一下网上的一篇代码,看到他用的是一个结构体数组,我在考虑是不是动态开辟结构体浪费了时间,于是我改成用结构体数组,结果还是超时。

看来并非单单是数组这个原因造成我的代码超时( 当然我感觉,数组应该确实 比动态 开辟 省点时间)

2.

然后我继续想。。。

我突然间想到一个问题,那就是在我的代码中,有几句这样的 语句

if(p2->lchild==NULL)
{
p2->lchild=p3;
break;
}
else if(p2->lchild!=NULL)//超时原因
p2=p2->lchild;

看到没有? 就是有一些没必要的判断,

在           if(p2->lchild==NULL)  这一句判断完之后,

下面的  else if(p2->lchild!=NULL)//超时原因    这一句纯属多余

于是我就抱着试试看的心态改了一下。

改过来之后 ,发现超时原因的确如此。

之所以这么写,我还是感觉自己容易出错,有时候考虑不周,所以都加上了 if() 条件判断,当时是为了避免出错 ,才这么写的。

所以养成了一点点的习惯这么写。

没想到。。。。这么写后造成超时,看来还是得改正这种写法,没必要的判断别用  -----------直接用   else   语句

代码2:正确

#include<iostream>
#include<cstring>
#include<stdio.h>
using namespace std; char c[100][100];
struct node
{
char c;
node *lchild;
node *rchild;
}; void f(node *p)//前序遍历输出,用递归
{
printf("%c",p->c);
if(p->lchild!=NULL)
f(p->lchild);
if(p->rchild!=NULL)
f(p->rchild);
} int main()
{
int i;
int j;
int exit;
exit=0;
while(1)
{
memset(c,'\0',sizeof(c));
i=0;
while(1)
{
scanf("%s",c[i]);
if(c[i][0]=='*'||c[i][0]=='$')
{
if(c[i][0]=='$')
exit=1;
break;
}
i++;
}
i--;
node *p=new node;
p->c=c[i][0];
p->lchild=NULL;
p->rchild=NULL;
i--;
node *p2;
while(i>=0)//遍历i --------此处为修改的上面代码 ( 修改前出现了 runtime error ),应该 把 i > = 0 的 判断放在前面
{
j=0;
while(1)//遍历j
{
p2=p;
node *p3=new node;//存储字母节点
p3->c=c[i][j];
p3->lchild=NULL;
p3->rchild=NULL;
while(1)//把字母挂到树中
{
if(p3->c < p2->c)
{
if(p2->lchild==NULL)
{
p2->lchild=p3;
break;
}
else // 修正 上面代码
p2=p2->lchild;
}
else // 修正 上面代码
{
if(p2->rchild==NULL)
{
p2->rchild=p3;
break;
}
else // 修正 上面代码
p2=p2->rchild;
}
}
j++;
if(c[i][j]=='\0')
break;
}
i--;
}
f(p);
printf("\n");
if(exit==1)
break;
}
return 0;
}

ps:再看这段代码,其实超时原因不是因为else if

而是p3->c > p2->c应该为p3->c >= p2->c

。。。

POJ 1577 Falling Leaves(二叉搜索树)的更多相关文章

  1. POJ 1577 Falling Leaves 二叉搜索树

    HDU 3791 Falling Leaves 二叉搜索树  Figure 1Figure 1 shows a graphical representation of a binary tree of ...

  2. 【二叉搜索树】poj 1577 Falling Leaves

    http://poj.org/problem?id=1577 [题意] 有一颗二叉搜索树,每次操作都把二叉搜索树的叶子从左到右揪掉(露出来的父节点就变成了新的叶子结点) 先给出了揪掉的叶子序列(多个字 ...

  3. Poj 2255 Tree Recovery(二叉搜索树)

    题目链接:http://poj.org/problem?id=2255 思路分析:根据先序遍历(如DBACEGF)可以找出根结点(D),其后为左右子树:根据中序遍历(如ABCDEFG),已知根结点(D ...

  4. POJ 1577 Falling Leaves (子母二叉树,给出叶子节点的删除序列,求前序遍历)

    题意:给出一棵字母二叉树删除叶子节点的序列,按删除的顺序排列.让你输出该棵二叉树额前序遍历的序列.思路:先把一棵树的所有删除的叶子节点序列存储下来,然后从最后一行字符串开始建树即可,最后遍历输出.   ...

  5. POJ 1577 Falling Leaves

    题意:给出一些字符串,从上到下的建树,输出其前序遍历 像前面那一题一样,先建树,然后再递归前序遍历 不过想像上一题那样用数组建树,建树和上题一样的办法,可是应该怎么输出前序遍历呢= = 还是看的题解= ...

  6. POJ 2309 BST(二叉搜索树)

    思路:除以2^k,找到商为奇数的位置,k为层数,有2^(k+1)-1个节点 这里直接用位运算,x & -x 就求出 2^k 了. #include<iostream> using ...

  7. 二叉搜索树 POJ 2418 Hardwood Species

    题目传送门 题意:输入一大堆字符串,问字典序输出每个字符串占的百分比 分析:二叉搜索树插入,然后中序遍历就是字典序,这里root 被new出来后要指向NULL,RE好几次.这题暴力sort也是可以过的 ...

  8. [数据结构]——二叉树(Binary Tree)、二叉搜索树(Binary Search Tree)及其衍生算法

    二叉树(Binary Tree)是最简单的树形数据结构,然而却十分精妙.其衍生出各种算法,以致于占据了数据结构的半壁江山.STL中大名顶顶的关联容器--集合(set).映射(map)便是使用二叉树实现 ...

  9. PAT树_层序遍历叶节点、中序建树后序输出、AVL树的根、二叉树路径存在性判定、奇妙的完全二叉搜索树、最小堆路径、文件路由

    03-树1. List Leaves (25) Given a tree, you are supposed to list all the leaves in the order of top do ...

随机推荐

  1. 启用nginx报错80端口被占用

    最近在本机跑nginx,启动后报错,怀疑80端口被占用 netstat -ano|findstr 尝试一:查看后发现端口被一个System pid 为4的一个程序占用.我在资源管理器中尝试将Syste ...

  2. SQL索引及表的页的逻辑顺序与物理顺序

    1.经过测试发现当聚集索引新建或者重建时,会按照逻辑顺序重新排列数据页和数据页内的数据行的物理顺序. 2.但修改表时,无论是聚集索引还是堆的数据页都是按自然顺序向后插入数据,页面上的偏移量可以证明.因 ...

  3. Idea中优化Markdown Support显示效果

    转自:https://www.jianshu.com/p/d093c42a8c29 因为工作中为提高工作效率,我一般习惯于直接在`idea`中使用`markdow support`插件来进行相关文档的 ...

  4. spring mvc数据验证

    今天来说一下.前段验证,与后端数据验证.大家都知道.在我们.注册与登陆的时候,往往需要对数据进行效验.那么前段我们都知道,可以使用,js去做处理. 今天主要讲解.后端的数据效验.这里我们采用Hiber ...

  5. [转]基于Python的接口测试框架

    http://blog.csdn.net/wyb199026/article/details/51485322 背景 最近公司在做消息推送,那么自然就会产生很多接口,测试的过程中需要调用接口,我就突然 ...

  6. [Android Studio 权威教程]AS 中配置强大的版本号管理系统(Git、SVN、等)

    在Eclipse中加入Git等版本号管理工具须要自己加入插件.并且个人认为不咋好用,在AS中已经给我们集成好了,我们仅仅须要配置一下就OK了.今天就和大家聊聊怎么配置以及使用的要点. 1. 安装Git ...

  7. c语言的编译和运行流程

    C语言源程序经过编译器进行词法分析 语法分析 等过程生成中间语言(object后缀的文件)编译期间会生成一个字符表和静态分配空间(如new static 全局变量)它们所需的内存空间可以计算出来放在链 ...

  8. ACboy needs your help(简单DP)

    HDU 1712 Problem Description ACboy has N courses this term, and he plans to spend at most M days on ...

  9. [转载] 把Nutch爬虫部署到Hadoop集群上

    http://f.dataguru.cn/thread-240156-1-1.html 软件版本:Nutch 1.7, Hadoop 1.2.1, CentOS 6.5, JDK 1.7 前面的3篇文 ...

  10. 基于SQLAIchemy的Flask目录

    预先知识 flask的基本使用 快速搭建开发的目录,以后我们在用Flask开发项目的时候可以直接用这个目录,不需要再自己创建. flask-sqlalchemy flask-sqlalchemy相当于 ...