题解 P1364 【医院设置】

ShineEternal

2018-07-03 17:11:01

Solution

这是一道简单的二叉树应用问题,问题中的结点数并不多,数据规模也不大,采用邻接矩阵存储,用Floyed法求出任意两结点之间的最短路径长,然后穷举医院可能建立的n个结点位置,找出一个最小距离的位置即可。当然也可以用双链表结构或带父结点信息的数组存储结构来解决,但实际操作稍微麻烦了一点。 ``` #include<cstdio> using namespace std; int a[101],g[101][101]; int main() { int n,l,r,min,total; scanf("%d",&n); for(int i=1;i<=n;i++) { for(int j=1;j<=n;j++) { g[i][j]=1000000; } } for(int i=1;i<=n;i++)//读入、初始化 { g[i][i]=0; scanf("%d%d%d",&a[i],&l,&r); if(l>0)g[i][l]=g[l][i]=1; if(r>0)g[i][r]=g[r][i]=1; } for(int k=1;k<=n;k++)//用Floyed求任意两结点之间的最短路径 { for(int i=1;i<=n;i++) { if(i!=k) { for(int j=1;j<=n;j++) { if(i!=j&&k!=j&&g[i][k]+g[k][j]<g[i][j]) g[i][j]=g[i][k]+g[k][j]; } } } } min=0x7fffffff; for(int i=1;i<=n;i++)//穷举医院建在N个结点,找出最短距离 { total=0; for(int j=1;j<=n;j++) total+=g[i][j]*a[j]; if(total<min)min=total; } printf("%d",min); return 0; } ``` 在各种竞赛中经常遇到这样的问题:N-1条公路连接着N个城市,从每个城市出发都可以通过公路到达其它任意的城市。每个城市里面都有一定数量的居民,但是数量并不一定相等,每条公路的长度也不一定相等。X公司(或者是政府)决定在某一个城市建立一个医院/酒厂/游乐场……,问:将它建在哪里,可以使得所有的居民移动到那里的总耗费最小?这种题目都是本题的“变型”,一般称为“树的中心点问题”。 **选自一本通,希望给大家提供精准的题解** 求过