【题目链接】:https://hihocoder.com/problemset/problem/1490

【题意】



给你一棵树的以下信息:

1.节点个数

2.给出树的每一层从左到右的顺序每个节点的编号

3.哪些节点是叶子节点

然后树中的边被去掉了;

让你复原出原图(树)

【题解】



这是道模拟题.

从最下层到上一层,从最左边的节点到右边的节点往上接父亲节点就好;

具体实现的时候;

直接找上一层最左边的且没被其他节点当爸爸的、且不为叶子节点的节点当爸爸就好;

当了爸爸之后

更新那个爸爸到其他所有节点的距离就好(不只是叶子节点,因为等会这个节点会成为新的“最底层”的节点了,你要为下一次的循环做铺垫);

然后,如果这一层里面,有和这个节点的距离为2的相邻的节点->那么它们两个可以共用一个父亲.

否则再重复找一个新的爸爸就好.



【Number Of WA】



0



【完整代码】

#include <bits/stdc++.h>
using namespace std;
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define mp make_pair
#define pb push_back
#define fi first
#define se second
#define ms(x,y) memset(x,y,sizeof x) typedef pair<int,int> pii;
typedef pair<LL,LL> pll; const int dx[9] = {0,1,-1,0,0,-1,-1,1,1};
const int dy[9] = {0,0,0,-1,1,-1,1,-1,1};
const double pi = acos(-1.0);
const int N = 110; int n,m,k,deps[N],a[N][N],dis[N][N];
int yezi[N],fa[N],isyezi[N]; void gengxin(int x)
{
rep1(i,1,n)
if (dis[i][x])
dis[i][fa[x]]=dis[fa[x]][i] = dis[i][x]-1;
} int main()
{
//freopen("F:\\rush.txt","r",stdin);
cin >> n >> m >> k;
rep1(i,1,m)
cin >> deps[i];
rep1(i,1,m)
rep1(j,1,deps[i])
cin >> a[i][j];
rep1(i,1,k) cin >> yezi[i],isyezi[yezi[i]] = 1;
rep1(i,1,k)
rep1(j,1,k)
cin >> dis[yezi[i]][yezi[j]];
fa[a[1][1]] = 0;
rep2(sd,m,2)
{
int u = -1,pre = 0;
rep1(i,1,deps[sd])
{
int v = a[sd][i];
if (u!=-1 && dis[u][v]==2)
fa[v] = fa[u];
else
{
int idx = 1;
rep1(j,pre+1,deps[sd-1])
if (!isyezi[a[sd-1][j]])
{
pre = j;
break;
}
fa[v] = a[sd-1][pre];
u = v;
gengxin(v);
}
}
}
rep1(i,1,n)
{
cout << fa[i];
if (i==n)
cout << endl;
else
cout << ' ';
}
return 0;
}

【微软2017年预科生计划在线编程笔试 B】Tree Restoration的更多相关文章

  1. hihocoder1489 Legendary Items (微软2017年预科生计划在线编程笔试)

    http://hihocoder.com/problemset/problem/1489 笔试题第一道,虽然说第一道都很水,但是我感觉这题不算特别水把..这道题我就卡住了我记得,tle,最后只有30分 ...

  2. 微软2017年预科生计划在线编程笔试 A Legendary Items

    思路: 获得第i(i = 0, 1, ..., n - 1)件物品的概率仅由公式p / (1 << i)决定,所以获得这i件物品之间是相互独立的.迭代计算获得所有i件物品的期望再求和即可. ...

  3. 【微软2017年预科生计划在线编程笔试 A】Legendary Items

    [题目链接]:https://hihocoder.com/problemset/problem/1489 [题意] 每轮游戏; 你一开始有p的概率获得超神标记; 如果这轮游戏你没获得超神标记; 那么你 ...

  4. 【微软2017年预科生计划在线编程笔试第二场 B】Diligent Robots

    [题目链接]:http://hihocoder.com/problemset/problem/1498 [题意] 一开始你有1个机器人; 你有n个工作; 每个工作都需要一个机器人花1小时完成; 然后每 ...

  5. 【微软2017年预科生计划在线编程笔试第二场 A】Queen Attack

    [题目链接]:http://hihocoder.com/problemset/problem/1497 [题意] 给你n个皇后; 然后问你其中能够互相攻击到的皇后的对数; 皇后的攻击可以穿透; [题解 ...

  6. Queen Attack -- 微软2017年预科生计划在线编程笔试第二场

    #!/usr/bin/env python # coding:utf-8 # Queen Attack # https://hihocoder.com/problemset/problem/1497 ...

  7. 2015-微软预科生计划-面试题-Swimming Plans

    http://hihocoder.com/problemset/problem/1188 题目大意 Steven在时刻T到达了室内游泳池. 游泳池一共有N条泳道,游泳池两侧分别标记为0和1. 已知除了 ...

  8. [转]微软联合CSDN英雄在线编程大赛

    2014 新年将至,微软联合CSDN英雄会共同举办本次第三届在线编程大赛,题目详情如下: 有一个字符串"iinbinbing",截取不同位置的字符‘b’.‘i’.‘n’.‘g’组合 ...

  9. 算法与数据结构(2)--英雄会第三届在线编程大赛:几个bing

    基础知识的回顾不再写到这里面了,会写一些算法算法的解答或者读一些相关书籍的笔记. 今天做了一道算法题,来自微软必应·英雄会第三届在线编程大赛:几个bing? 做出来了...但不知道为啥执行测试用例失败 ...

随机推荐

  1. Codeforces Round #330 (Div. 2) D. Max and Bike 二分

    D. Max and Bike For months Maxim has been coming to work on his favorite bicycle. And quite recently ...

  2. hdu 1874(最短路 Dilkstra +优先队列优化+spfa)

    畅通工程续 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  3. Webkit内核开源爬虫蜘蛛引擎

    C#开发的基于Webkit内核开源爬虫蜘蛛引擎 https://www.cnblogs.com/micro-chen/p/9075590.html 概述 在各个电商平台发展日渐成熟的今天.很多时候,我 ...

  4. [NOIP 2014] 寻找道路

    [题目链接] http://uoj.ac/problem/19 [算法] 首先,在反向图上从终点广搜,求出每个点是否可以在答案路径中 然后在正向图中求出源点至终点的最短路,同样可以使用广搜 时间复杂度 ...

  5. bzoj 2252 [ 2010 Beijing wc ] 矩阵距离 —— 多源bfs

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2252 又没能自己想出来... 一直在想如何从每个1开始广搜更新答案,再剪剪枝,什么遇到1就不 ...

  6. A - Word

    Problem description Vasya is very upset that many people on the Net mix uppercase and lowercase lett ...

  7. Ubuntu下搭建repo服务器(一): 配置gitosis

    1. 说明 服务器端IP: 192.168.1.126,下文简称:A端: 客户端IP: 192.168.130.19,下文简称:B端: Android工程代号:17435. 2. 安装必要软件(A端) ...

  8. SQLServer2008 关于while循环

    有这样一个表tbl id  code name 11   a      aa/bb/cc 22   b      ee/rr/tt 需要将name段根据‘/’拆分开来,变成新的数据行 即: id  c ...

  9. android黑科技系列——爆破一款应用的签名验证问题

    一.前言 在之前的文章中说过Android中的安全和破解是相辅相成的,为了防止被破解,很多应用做了一些防护策略,但是防护策略也是分等级,一般简单的策略就是混淆代码和签名校验,而对于签名校验很多应用都是 ...

  10. Android_传感器光学

    上一篇写了一个小案例方向传感器,与这光学传感器原理大致类似,但其实代码的主要区别得到的类型不一样在这里我一一列举出来: * Sensor.TYPE_ORIENTATION:方向传感器. * Senso ...