1. 设有一棵二叉树,如图:
  2. 【我是图】
  3. 其中,圈中的数字表示结点中居民的人口。圈边上数字表示结点编号,现在要求在某个结点上建立一个医院,使所有居民所走的路程之和为最小,同时约定,相邻接点之间的距离为1。如上图中,
  4. 若医院建在1 处,则距离和=4+12+2*20+2*40=136;若医院建在3 处,则距离和=4*2+13+20+40=81……
  5. 输入输出格式
  6. 输入格式:
  7. 第一行一个整数n,表示树的结点数。(n100)
  8. 接下来的n行每行描述了一个结点的状况,包含三个整数,整数之间用空格(一个或多个)分隔,其中:第一个数为居民人口数;第二个数为左链接,为0表示无链接;第三个数为右链接。
  9. 输出格式:
  10. 一个整数,表示最小距离和。
  11. 输入输出样例
  12. 输入样例#1 复制
  13. 5
  14. 13 2 3
  15. 4 0 0
  16. 12 4 5
  17. 20 0 0
  18. 40 0 0
  19. 输出样例#1 复制
  20. 81

以每个节点为医院,枚举距离。(floyd?)

顺带邻接表。

  1. //Writer:GhostCai && His Yellow Duck
  2. #include<iostream>
  3. #include<cstring>
  4. #define MAXN 2000
  5. using namespace std;
  6. //
  7. struct edge{
  8. int to,next;
  9. }e[MAXN];
  10. int cnt,head[MAXN];
  11. void add(int x,int y){
  12. e[++cnt].to = y;
  13. e[cnt].next = head[x];
  14. head[x]=cnt;
  15. }
  16. //
  17. int n,ans=1<<30;
  18. int dis[MAXN],num[MAXN];
  19. bool vis[MAXN];
  20. void dfs(int id,int dp){
  21. int i;
  22. for(i=head[id];i!=-1;i=e[i].next){
  23. if(!e[i].to || vis[e[i].to ]) continue;
  24. vis[e[i].to ]=1;
  25. dis[e[i].to] = dp+1;
  26. dfs(e[i].to , dp+1);
  27. }
  28. }
  29. int main(){
  30. cin>>n;
  31. int i,j,x,y;
  32. memset(head,-1,sizeof(head));
  33. for(i=1;i<=n;i++){
  34. cin>>num[i]>>x>>y;
  35. add(i,x);add(x,i);
  36. add(i,y);add(y,i);
  37. }
  38. for(i=1;i<=n;i++){
  39. memset(dis,0,sizeof(dis));
  40. memset(vis,0,sizeof(vis));
  41. vis[i]=1;//!!!
  42. dfs(i,0);
  43. int sum=0;
  44. for(j=1;j<=n;j++){
  45. sum+=num[j]*dis[j];
  46. }
  47. ans=min(sum,ans);
  48. }
  49. cout<<ans<<endl;
  50. return 0;
  51. }

[LUOGU] 1364 医院设置的更多相关文章

  1. luogu P1364 医院设置

    题目描述 设有一棵二叉树,如图: 其中,圈中的数字表示结点中居民的人口.圈边上数字表示结点编号,现在要求在某个结点上建立一个医院,使所有居民所走的路程之和为最小,同时约定,相邻接点之间的距离为1.如上 ...

  2. 【6.10校内test】T2 医院设置

    医院设置[题目链接] 感觉我超废 我是一个连floyd都不会写了的灵魂OI选手qwq(考场上写了半天spfa然后写炸了(微笑)) floyd的暴力: 1.先建树:用邻接矩阵存.存之前记得先初始化为IN ...

  3. codevs 2577 医院设置

    2577 医院设置 时间限制: 1 s 空间限制: 32000 KB 题目等级 : 黄金 Gold   题目描述 Description 设有一棵二叉树,如下图 其中,圈中数字表示结点居民的人口.圈边 ...

  4. 医院设置x

    医院设置x   题目描述 Description 设有一棵二叉树,如下图 其中,圈中数字表示结点居民的人口.圈边上数字表示结点编号,.现在要求在某个结点上建立一个医院,使所有居民所走的路程之和为最小, ...

  5. P1364 医院设置 (补锅,memset初始化较大值不可用0x7fffffff )

    P1364 医院设置 题解 弗洛伊德水过 注意初始化一个大数 0x3f 可以,0x5f 好像也可以,但是0x7fffffff 我是真的炸了,初始化为-1 (后面补锅有详细解释) 代码 #include ...

  6. 【模板】树的重心 洛谷P1364 医院设置

    P1364 医院设置 题目描述 设有一棵二叉树,如图: 其中,圈中的数字表示结点中居民的人口.圈边上数字表示结点编号,现在要求在某个结点上建立一个医院,使所有居民所走的路程之和为最小,同时约定,相邻接 ...

  7. P1364 医院设置 洛谷

    https://www.luogu.org/problem/show?pid=1364 题目描述 设有一棵二叉树,如图: 其中,圈中的数字表示结点中居民的人口.圈边上数字表示结点编号,现在要求在某个结 ...

  8. 洛谷P1364 医院设置(Floyd)

    题目描述 设有一棵二叉树,如图: 其中,圈中的数字表示结点中居民的人口.圈边上数字表示结点编号,现在要求在某个结点上建立一个医院,使所有居民所走的路程之和为最小,同时约定,相邻接点之间的距离为l.如上 ...

  9. [Swust OJ 412]--医院设置(floyd算法)

    题目链接:http://acm.swust.edu.cn/problem/412/ Time limit(ms): 1000 Memory limit(kb): 65535   Description ...

随机推荐

  1. (十三)SpringBoot 发送E-mail

    一:添加mail依赖 <dependency> <groupId>org.springframework.boot</groupId> <artifactId ...

  2. Pycharm2018.3.1永久激活

    Pycharm Professional 2018.3.1 版已正式发布,新版本添加对Python3.7的支持.作为强大的开发工具,但每次注册让人头疼,本着分享的心态,提供以下解决方案,亲测有效!本方 ...

  3. Spring源码(一)

    <listener> <listener-class>org.springframework.web.context.ContextLoaderListener</lis ...

  4. Markdown - 如何使用上标、下标

    解决方法 Markdown可以和HTML的语法兼容,可以通过HTML的上标和下标标签来实现效果: 标签 写法 效果 上标 2<sup>10</sup> 210 下标 H< ...

  5. Centos 7.x 安装 MongoDB

    官方安装资料:点击直达 本次以Centos为安装主机 1:首先先导入MongoDB的yum源,因为Centos默认是没有MongoDB的yum源,创建文件:/etc/yum.repos.d/mongo ...

  6. c#中的特性

    c#中的特性 特性在我的理解就是在类或者方法或者参数上加上指定的标记,然后实现指定的效果. 和Java中的注解@Annotation类似. c#内置的特性之Obsolete [Obsolete(&qu ...

  7. PHP知识点总结2

    PHP5数据类型 String(字符串), Integer(整型), Float(浮点型), Boolean(布尔型), Array(数组), Object(对象), NULL(空值). 字符串 你可 ...

  8. 设置Eclipse可以Debug模式调试JDK源码,并显示局部变量的值

    最近突然萌发了研究JDK源码的想法,所以就想到了在自己常用的Eclipse上可以调试JDK源码. 整个设置过程也很简单: 首先你要安装好JDK(我的JDK安装路径根目录是D:\Java\jdk-8u9 ...

  9. 2189 数字三角形W

    2189 数字三角形W 时间限制: 1 s 空间限制: 32000 KB 题目等级 : 黄金 Gold       题目描述 Description 数字三角形要求走到最后mod 100最大 输入描述 ...

  10. 【NumPy学习指南】day4 多维数组的切片和索引

    ndarray支持在多维数组上的切片操作.为了方便起见,我们可以用一个省略号(...)来 表示遍历剩下的维度. (1) 举例来说,我们先用arange函数创建一个数组并改变其维度,使之变成一个三维数组 ...