算法与数据结构实验题 6.3 search
★实验任务
可怜的 Bibi 刚刚回到家,就发现自己的手机丢了,现在他决定回头去搜索 自己的手机。
现在我们假设 Bibi 的家位于一棵二叉树的根部。在 Bibi 的心中,每个节点 都有一个权值 x,代表他心中预感向这个节点走可能找回自己手机的程度(虽然 他的预感根本不准)。当 Bibi 到达一个节点时,如果该节点有未搜索过的儿子节 点,则 Bibi 会走向未搜索过的儿子节点进行搜索,否则就返回父亲节点。如果 某节点拥有两个未搜索过的儿子节点,Bibi 会选择先搜索权值大的儿子节点。
假设 Bibi 从一个节点到达另一个节点需要 1 单位时间,搜索节点的时间忽 略不计,那么请问当 Bibi 的手机位于编号为 k 的节点时,他需要多少单位时间 才能找到手机。
★数据输入
输入第一行为一个正整数 n(1≤n≤100000)表示树的节点数目,树根的编号 总是为 1。
接下来 n-1 行,每行两个正整数 p,x(1≤x≤100)。代表编号为 i 的节点的父 亲节点 p 和权值 x。这里的 i 从 2 依次数到 n。数据保证输入的 p 小于当前的 i, 且互为兄弟的两个节点的权值 x 不同。
第 n+1 行一个整数 m(1≤m≤n), 表示询问组数。
第 n+2 行有 m 个整数,每个整数 ki(1≤ki≤n)代表该组询问中手机的位置。
★数据输出
输出 m 行,每行一个整数,代表 Bibi 找到手机需要花费的单位时间数量。
| 输入示例 | 输出示例 |
|---|---|
| 3 1 20 1 30 3 1 2 3 |
0 3 1 |
思路
建立一个递归过程来模拟这个搜索过程:
1.用一个变量sum来保存当前走了多少步
2.建立结构体(用父节点表示法建立数组)
struct Tree
{
int value; //保存当前节点的权值
int step; //记录走到该节点的步数
int left; //左儿子编号
int right; //右儿子编号
};
3.递归函数
void search(int i)
{
tree[i].step = sum; //更新该节点的step值
if (tree[i].left == 0 && tree[i].right == 0) //判断该节点是否为叶节点
{
sum++; //返回上一个节点步数+1
return;
}
if (tree[tree[i].left].value>tree[tree[i].right].value) //左儿子权值大于右儿子
{
//tree[i].step += sum++;
sum++; //即将搜索左儿子步数+1
search(tree[i].left); //搜索左儿子
if (tree[tree[i].right].value) //判断是否存在右儿子
{
sum++; //即将搜索右儿子步数+1
search(tree[i].right); //搜索右儿子
}
}
else
{
//tree[i].step += sum++;
sum++;
search(tree[i].right);
if (tree[tree[i].left].value)
{
sum++;
search(tree[i].left);
}
}
sum++; //左右儿子搜索完毕之后返回上个节点步数+1
}
4.递归函数之后每个节点的step值都会被更新,这样我们只要输入节点编号,访问step值就能知道找到这个节点要走多少步了。
Code
#include<stdio.h>
#include<iostream>
#include<string.h>
using namespace std;
struct Tree
{
int value;
int step;
int left;
int right;
};
Tree tree[100001] = { 0 };
int sum = 0;
void search(int i)
{
tree[i].step = sum;
if (tree[i].left == 0 && tree[i].right == 0)
{
sum++;
return;
}
if (tree[tree[i].left].value>tree[tree[i].right].value)
{
//tree[i].step += sum++;
sum++;
search(tree[i].left);
if (tree[tree[i].right].value)
{
sum++;
search(tree[i].right);
}
}
else
{
//tree[i].step += sum++;
sum++;
search(tree[i].right);
if (tree[tree[i].left].value)
{
sum++;
search(tree[i].left);
}
}
sum++;
}
int main()
{
int n;
int m;
int x;
int y;
int i;
int k;
//printf("%d\n", tree[0].value);
scanf("%d", &n);
tree[1].value = 0;
tree[1].step = 0;
for (i = 2; i <= n; i++)
{
scanf("%d %d", &x, &y);
if (!tree[x].left)
{
tree[x].left = i;
tree[i].value = y;
}
else
{
tree[x].right = i;
tree[i].value = y;
}
}
search(1);
scanf("%d", &m);
for (i = 1; i <= m; i++)
{
scanf("%d", &k);
printf("%d", tree[k].step);
if (i<n)printf("\n");
}
return 0;
}
算法与数据结构实验题 6.3 search的更多相关文章
- 算法与数据结构实验题 6.4 Summary
★实验任务 可怜的 Bibi 丢了好几台手机以后,看谁都像是小偷,他已经在小本本上记 下了他认为的各个地点的小偷数量. 现在我们将 Bibi 的家附近的地形抽象成一棵有根树.每个地点都是树上的 一个节 ...
- 算法与数据结构实验题 4.2 小 F 打怪
★实验任务 小 F 很爱打怪,今天因为系统 bug,他提前得知了 n 只怪的出现顺序以及击 倒每只怪得到的成就值 ai.设第一只怪出现的时间为第 1 秒,这个游戏每过 1 秒 钟出现一只新怪且没被击倒 ...
- 算法与数据结构实验题 4.1 伊姐姐数字 game
★实验任务 伊姐姐热衷于各类数字游戏,24 点.2048.数独等轻轻松松毫无压力.一 日,可爱的小姐姐邀请伊姐姐一起玩一种简单的数字 game,游戏规则如下: 一开始桌上放着 n 张数字卡片,从左到右 ...
- 算法与数据结构实验题6.4 order (二叉树)
1.题目: 2.代码: #include<iostream> #include<algorithm> using namespace std; struct Node { in ...
- 算法与数据结构实验题 5.2 Missile
1.题目: 2.解题思路: 把每个点对应的两条半径求出,之后对d1进行升序排序,对应d2也改变位置.其中一个圆心的半径r1确定之后,除去第一个圆包围的点,在其余点中找到另外一个圆的最长的半径r2,此时 ...
- 算法与数据结构基础 - 折半查找(Binary Search)
Binary Search基础 应用于已排序的数据查找其中特定值,是折半查找最常的应用场景.相比线性查找(Linear Search),其时间复杂度减少到O(lgn).算法基本框架如下: //704. ...
- 基础算法和数据结构高频题 II
DFS的两种理解方式:1. 按照实际执行顺序模拟 (适合枚举型DFS,下节课内容)2. 按照DFS的定义宏观理解 (适合分治型DFS,本节课内容) 1 Convert BST to Greater T ...
- 第三章 基础算法和数据结构高频题 I
区间类问题 1 Missing Interval public List<String> findMissingRanges(int[] nums, int lower, int uppe ...
- DS实验题 sights
算法与数据结构实验题 6.3 sights ★实验任务 美丽的小风姑娘打算去旅游散心,她走进了一座山,发现这座山有 n 个景点, 由于山路难修,所以施工队只修了最少条的路,来保证 n 个景点联通,娇弱 ...
随机推荐
- 第6章 HDFS HA配置
目录 6.1 hdfs-site.xml文件配置 6.2 core-site.xml文件配置 6.3 启动与测试 6.4 结合ZooKeeper进行自动故障转移 在Hadoop 2.0.0之前,一个H ...
- mt7620a拓展串口
mt7620a拓展串口 要修改的文件有两个: mt7620a.dtsi 进入/home/ihid/chaos_calmer/target/linux/ramips/dts/mt7620a.dtsi p ...
- python闭包的概念及使用
闭包:在函数里定义了另外一个函数(函数嵌套),内函数里运用了外函数的变量,外函数返回内函数的函数引用(函数名). nonlocal 的使用:闭包内部函数可直接调用外部函数的变量,如果修改需要使用non ...
- 利用cross-entropy cost代替quadratic cost来获得更好的收敛
1.从方差代价函数说起(Quadratic cost) 代价函数经常用方差代价函数(即采用均方误差MSE),比如对于一个神经元(单输入单输出,sigmoid函数),定义其代价函数为: 其中y是我们期望 ...
- 20145226夏艺华 逆向及Bof基础实践
逆向及Bof基础实践 实践目标 本次实践的对象是一个名为pwn1的linux可执行文件. 该程序正常执行流程是:main调用foo函数,foo函数会简单回显任何用户输入的字符串,如图所示: 该程序同时 ...
- 天津Uber优步司机奖励政策(1月4日~1月10日)
滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万/不用抢单:http://www.cnblogs.com/mfry ...
- P1563 玩具谜题
P1563 玩具谜题 题目描述 小南有一套可爱的玩具小人, 它们各有不同的职业. 有一天, 这些玩具小人把小南的眼镜藏了起来. 小南发现玩具小人们围成了一个圈,它们有的面朝圈内,有的面朝圈外.如下图: ...
- Intellij打包jar文件,“java.lang.SecurityException: Invalid signature file digest for Manifest main attrib
下面是使用Intellij 打包jar文件的步骤,之后会有运行jar文件时遇到的错误. 打包完成. ================================================== ...
- cocos2d-x3.7 cclabel文字破碎,异常,变乱
效果图如下: 无论是按钮(control button),还是普通的label都有小概率出现这种情况. 该问题发现于cocos2d-x3.7 原因: 在3.x中使用ttfconfig创建的label, ...
- Servlet处理文件下载的编码问题,乱码。
Servlet处理文件下载的编码问题,乱码. //处理文件名乱码问题 // 获得请求头中的User-Agent String agent = request.getHeader("User- ...