★实验任务

fd是一个公认的美丽校园。一天,fd来了一群地鼠,编号为1到n,他们希望在这里定居。现在先由第一只地鼠往下打一个单位的距离,并且在那里安家。对于每一个已经安家的地鼠,如果他左下或右下没有邻居,那还没安家的地鼠就可以在他的左下或者右下安家。地鼠们已经建完所有的窝了,他们评价这些窝合格的标准是它们能不能形成一棵二叉搜索树(二叉搜索树的定义见课本)。现在需要你帮助他们评估一下他们的窝挖的是否合格。

★数据输入

第1行一个整数n,表示地鼠总共n只。接下来一共n行,每一行三个数:l,o,r,其中l表示编号为o的地鼠的左邻居的编号,r表示的是编号为o的右邻居的编号,如果没有左邻居或右邻居,则l或r为-1。1<=n<=10000。保证给出的是一颗二叉树。

★数据输出

输出一行,如果如果他们的窝合格,则输出安居在最深的窝的地鼠离地面的距离,如果不合格,则输出-1。

输入示例

5

-1 1 -1

1 2 3

-1 3 -1

2 4 5

-1 5 -1

输出示例

3

代码实现

//
// main.cpp
// 地鼠打洞
//
// Created by wasdns on 16/10/26.
// Copyright © 2016年 wasdns. All rights reserved.
// #include <cstdio>
#include <iostream>
#include <cstdlib>
#include <string>
#include <stack>
using namespace std; #define fMax -10000; struct Tree {
Tree *l;
Tree *r;
int num;
int lnum;
int rnum;
int flag;
}s[10005]; /*
Tree* IniNode() {
Tree *p; p = new Tree;
if (p == NULL) {
cout << "Error" << endl;
exit(1);
} return p;
}
*/ Tree* CreatTree(int n) { int i, j; int lturn, rturn;
for (i = 0; i < n; i++) { lturn = s[i].lnum;
rturn = s[i].rnum; if (lturn == -1 && rturn == -1) continue; else { if (lturn != -1 && rturn == -1) { for (j = 0; j < n; j++) { if (s[j].num == lturn) {
s[i].l = &s[j];
s[j].flag = 1;
break;
}
}
} else if (lturn == -1 && rturn != -1) { for (j = 0; j < n; j++) { if (s[j].num == rturn) {
s[i].r = &s[j];
s[j].flag = 1;
break;
}
}
} else { for (j = 0; j < n; j++) { if (s[j].num == lturn) {
s[i].l = &s[j];
s[j].flag = 1;
} if (s[j].num == rturn) {
s[i].r = &s[j];
s[j].flag = 1;
}
}
}
}
} Tree *header;
for (i = 0; i < n; i++) { if (s[i].flag == 0) {
header = &s[i];
break;
}
} return header;
} int t = fMax; bool TreeJudge(Tree *p) { bool jr = true; if (p != NULL) { bool j1 = TreeJudge(p -> l); if (!j1) {
jr = false;
return jr;
} if (p -> num < t) {
jr = false;
return jr;
}
else {
t = p -> num;
} bool j2 = TreeJudge(p -> r); if (!j2) {
jr = false;
return jr;
}
} return jr;
} int TreeHeight(Tree* header) { int lheight = 0;
int rheight = 0; if (!header) return 0;
else { lheight = TreeHeight(header -> l);
rheight = TreeHeight(header -> r); if (lheight > rheight) {
return lheight + 1;
}
else {
return rheight + 1;
}
} return 0;
} int main() {
int n;
int i; cin >> n; for (i = 0; i < n; i++) {
cin >> s[i].lnum >> s[i].num >> s[i].rnum;
s[i].l = NULL;
s[i].r = NULL;
s[i].flag = 0;
} Tree *header;
header = CreatTree(n); if (!TreeJudge(header)) {
cout << "-1" << endl;
}
else {
cout << TreeHeight(header) << endl;
} return 0;
}

2016/10/30

DS实验题 地鼠安家的更多相关文章

  1. DS实验题 融合软泥怪-2 Heap实现

    题目和STL实现:DS实验题 融合软泥怪-1 用堆实现优先队列 引言和堆的介绍摘自:Priority Queue(Heaps)--优先队列(堆) 引言: 优先队列是一个至少能够提供插入(Insert) ...

  2. DS实验题 Old_Driver UnionFindSet结构 指针实现邻接表存储

    题目见前文:DS实验题 Old_Driver UnionFindSet结构 这里使用邻接表存储敌人之间的关系,邻接表用指针实现: // // main.cpp // Old_Driver3 // // ...

  3. DS实验题 Dijkstra算法

    参考:Dijkstra算法 数据结构来到了图论这一章节,网络中的路由算法基本都和图论相关.于是在拿到DS的实验题的时候,决定看下久负盛名的Dijkstra算法. Dijkstra的经典应用是开放最短路 ...

  4. DS实验题 sights

    算法与数据结构实验题 6.3 sights ★实验任务 美丽的小风姑娘打算去旅游散心,她走进了一座山,发现这座山有 n 个景点, 由于山路难修,所以施工队只修了最少条的路,来保证 n 个景点联通,娇弱 ...

  5. DS实验题 order

    算法与数据结构 实验题 6.4 order ★实验任务 给出一棵二叉树的中序遍历和每个节点的父节点,求这棵二叉树的先序和后序遍历. ★数据输入 输入第一行为一个正整数n表示二叉树的节点数目,节点编号从 ...

  6. DS实验题 Order 已知父节点和中序遍历求前、后序

    题目: 思路: 这题是比较典型的树的遍历问题,思路就是将中序遍历作为位置的判断依据,假设有个节点A和它的父亲Afa,那么如果A和Afa的顺序在中序遍历中是先A后Afa,则A是Afa的左儿子,否则是右儿 ...

  7. DS实验题 Inversion

    题目: 解题过程: 第一次做这题的时候,很自然的想到了冒泡和选择,我交的代码是用选择写的.基本全WA(摊手). 贴上第一次的代码: // // main.cpp // sequenceschange ...

  8. DS实验题 Missile

    题目: 提示:并没有精度问题. 原题 NOIP2010 导弹拦截 思路 设源点为A(x1, y1)和B(x2, y2). 第一步,用结构体存节点,包括以下元素: 1.横坐标x 2.纵坐标y 3.节点和 ...

  9. DS实验题 击鼓传花

    题目: 代码1(数组实现): // // main.cpp // DS-击鼓传花 // // Created by wasdns on 16/11/9. // Copyright © 2016年 wa ...

随机推荐

  1. Spring源码下载地址

    今天想下载一下Spring的源代码,登录到Spring官网,傻眼了,根本找不到下载的地方!费了九牛二虎之力在网上找到了一个下载地址,记下来,免得下次再次傻找. http://s3.amazonaws. ...

  2. Android实现高仿QQ附近的人搜索展示

    本文主要实现了高仿QQ附近的人搜索展示,用到了自定义控件的方法 最终效果如下 1.下面展示列表我们可以使用ViewPager来实现(当然如果你不觉得麻烦,你也可以用HorizontalScrollVi ...

  3. select into from 提示 Undeclared variable.....错误的解决办法 && select into from 和 insert into select 的用法和区别

    然而今天在使用 SELECT INTO FROM 备份mysql数据表的时候,运行相关 sql 语句的时候却一直返回 [Err] 1327 - Undeclared variable: ...... ...

  4. Sublime Text 插件 & 使用技巧

    20 个强大的 Sublime Text 插件http://blog.jobbole.com/58725/ 12个不可不知的Sublime Text应用技巧和诀窍http://segmentfault ...

  5. 使用github上的开源框架SlidingMenu环境的搭建,以及getSupportActionBar方法不能找到的问题

    http://blog.csdn.net/lovexieyuan520/article/details/9814273 使用github上的开源框架SlidingMenu环境的搭建,以及getSupp ...

  6. TextView属性大全

    今天研究了TextView一天了,发现网上有一篇讲TextView属性的,非常全,收藏一下先. 发现TextView有一个比较大的问题,就是文字排版的问题,遇到数字,字母,符号等就会有问题,目前还没有 ...

  7. loadrunner关联数组后拼凑字符串

    loadrunner拼接关联数组的元素 int arrSize=0; int index=1; int len=0; char arryStartString[1024]=""; ...

  8. .Net AppDomain.CurrentDomain.AppendPrivatePath(@"Libs");

    今天就说说.Net中通过反射取得某个类型时,我们怎么知道这个类型在硬盘上的哪个角落?比如说,假如我们需要要求服务端动态载入某个数据源,那服务端怎么知道数据源在哪?网上大部分的教程都写着,可以使用Ass ...

  9. json学习系列(2)-生成JSONObject的方法

    生成JSONObject一般有两种方式,通过javabean或者map类型来生成.如下面的例子: 先定义一个User实体类: package com.pcitc.json; /** * 用户实体类 * ...

  10. 状压DP SGU 223 Little Kings

    题目传送门 /* 题意:n*n的矩阵,放置k个king,要求king互相不能攻击,即一个king的8个方向都没有另外的king,求方案个数 状态压缩DP:dp[i][num[j]][s] 代表在第i行 ...