[SCOI2008]城堡
题目描述
在一个国家里,有n个城市(编号为0 到n-1)。这些城市之间有n条双向道
路相连(编号为0 到n-1),其中编号为i的道路连接了城市i和城市ri(一条道
路可以连接一个城市和它自身),长度为di。n 个城市中有m个拥有自己城堡,
可以抵御敌人侵略。如果没有城堡的城市遭受攻击,则离它最近的城堡将派兵前
往救援。
你的任务是在不超过k个没有城堡的城市中建立城堡,使得所有城市中“离
最近城堡的距离”的最大值尽量小。换句话说,若令dist(c)表示城市c的最近城
堡离它的距离,则你的任务是让max{dist(c)}尽量小。
输入数据保证存在方案使得对于每个城市,至少有一个城堡能够到达。
输入输出格式
输入格式:
输入第一行为三个正整数n, m, k。第二行包含n个整数r0,r1,…,rn-1。第三行
包含n 个整数d0,d1,…,dn-1。第四行包含m 个各不相同的0~n-1 之间的整数,分
别为m个城堡所在的城市编号。
输出格式:
输出仅一行,包含一个整数,即max{dist(c)}的最小值。
输入输出样例
说明
100%的数据满足:2<=n<=50, 1<=di<=106, 0<=m<=n-k
先存图,直接用floyd求出最短路
继续二分最大长度mid,对于每个已有城堡的城市,直接去标记其能到达的城市
然后对于不能到达的
我们将其距离不超过枚举的mid的点期望+1,分别在k次中每次找到最大期望的值进行建城堡。
有个玄学:在比较找出最大期望相同时要找编号尽量大的?????
复杂度O(n^3+logd*k*n^2)
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int n,m,k;
long long dis[][];
int cnt[],vis[],ans,p[],son[];
void find(int mid)
{int i,j,Max,maxi;
memset(cnt,,sizeof(cnt));
for (i=;i<=n;i++)
if (vis[i]==)
{
for (j=;j<=n;j++)
if (dis[i][j]<=mid)
cnt[j]++;
}
Max=,maxi=;
for (i=;i<=n;i++)
if (cnt[i]>=Max)
{
Max=cnt[i];
maxi=i;
}
if (maxi==) return;
for (i=;i<=n;i++)
if (dis[maxi][i]<=mid) vis[i]=;
}
bool check(int mid)
{int i,j;
memset(vis,,sizeof(vis));
for (i=;i<=m;i++)
{
for (j=;j<=n;j++)
if (dis[p[i]][j]<=mid) vis[j]=;
}
for (i=;i<=k;i++)
find(mid);
for (i=;i<=n;i++)
if (vis[i]==) return ;
return ;
}
int main()
{int i,j;
long long d;
cin>>n>>m>>k;
memset(dis,/,sizeof(dis));
for (i=;i<=n;i++)
{
scanf("%d",&son[i]);
son[i]++;
}
int l=,r=;
for (i=;i<=n;i++)
{
scanf("%lld",&d);
dis[i][son[i]]=min(dis[i][son[i]],d);
dis[son[i]][i]=min(dis[i][son[i]],d);
r+=d;
}
for (l=;l<=n;l++)
for (i=;i<=n;i++)
if (i!=l)
{
for (j=;j<=n;j++)
if (l!=j&&i!=j)
{
dis[i][j]=min(dis[i][j],dis[i][l]+dis[l][j]);
}
}
for (i=;i<=n;i++)
dis[i][i]=;
for (i=;i<=m;i++)
scanf("%d",&p[i]),p[i]++;
l=;
while (l<=r)
{
int mid=(l+r)/;
if (check(mid)) ans=mid,r=mid-;
else l=mid+;
}
cout<<ans;
}
[SCOI2008]城堡的更多相关文章
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- BZOJ 1078: [SCOI2008]斜堆
1078: [SCOI2008]斜堆 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 770 Solved: 422[Submit][Status][ ...
- 【BZOJ1076】[SCOI2008]奖励关 状压DP+期望
[BZOJ1076][SCOI2008]奖励关 Description 你正在玩你最喜欢的电子游戏,并且刚刚进入一个奖励关.在这个奖励关里,系统将依次随机抛出k次宝物,每次你都可以选择吃或者不吃(必须 ...
- vijos1059 积木城堡[n年浙江省队第X轮](背包的方案总数 or 01背包)
描述 XC的儿子小XC最喜欢玩的游戏用积木垒漂亮的城堡.城堡是用一些立方体的积木垒成的,城堡的每一层是一块积木.小XC是一个比他爸爸XC还聪明的孩子,他发现垒城堡的时候,如果下面的积木比上面的积木大, ...
- HDU1269 迷宫城堡
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...
- HD1269迷宫城堡(有向图 && 划分连通块)
迷宫城堡 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- 【bzoj1078】[SCOI2008]斜堆
2016-05-31 16:34:09 题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1078 挖掘斜堆的性质233 http://www.cp ...
- bzoj 3399: [Usaco2009 Mar]Sand Castle城堡
3399: [Usaco2009 Mar]Sand Castle城堡 Time Limit: 3 Sec Memory Limit: 128 MB Description 约翰用沙子建了一座城堡.正 ...
- hdu 1269 迷宫城堡 强连通分量
迷宫城堡 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
随机推荐
- 第二次作业--------STEAM
--------------------------------------第一部分 产品介绍----------------------------------------------------- ...
- C语言的第一次作业
一.PTA实验作业 题目1. 温度转换 本题要求编写程序,计算华氏温度150°F对应的摄氏温度.计算公式:C=5×(F−32)/9,式中:C表示摄氏温度,F表示华氏温度,输出数据要求为整型. 1.实验 ...
- Beta冲刺集合
1.Day1 http://www.cnblogs.com/bugLoser/p/8075868.html 2.Day2 http://www.cnblogs.com/bugLoser/p/80758 ...
- 201621123050 《Java程序设计》第3周学习总结
1. 本周学习总结 初学面向对象,会学习到很多碎片化的概念与知识.尝试学会使用思维导图将这些碎片化的概念.知识点组织起来.请使用工具画出本周学习到的知识点及知识点之间的联系.步骤如下: 1.1 写出你 ...
- 201621123057 《Java程序设计》第6周学习总结
1. 本周学习总结 1.1 面向对象学习暂告一段落,请使用思维导图,以封装.继承.多态为核心概念画一张思维导图或相关笔记,对面向对象思想进行一个总结. 注1:关键词与内容不求多,但概念之间的联系要清晰 ...
- ExecutorService,另一种服务,线程
http://heipark.iteye.com/blog/1393847 Executors.newFixedThreadPool和ArrayBlockingQueue一点使用心得 博客 ...
- 在Nginx上配置多个站点
有时候你想在一台服务器上为不同的域名运行不同的站点.比如www.siteA.com作为博客,www.siteB.com作为论坛.你可以把两个域名的IP都解析到你的服务器上,但是没法在Nginx的根目录 ...
- 在arc模式下 CGImage 释放问题
//大图bigImage //定义myImageRect,截图的区域 if (imagecount >= 3) { CGRect myImageRect; if (i.size.width< ...
- ebtables和iptables与linux bridge的交互
本文为翻译文,不一定是逐字逐句的翻译,而且中间会加上自己的一点见解,如有理解错误的地方,还请大家指出,我定虚心学习.原文见链接 其中斜体字是自己的理解,建议和ebtables手册和iptables手册 ...
- 爬虫小探-Python3 urllib.request获取页面数据
使用Python3 urllib.request中的Requests()和urlopen()方法获取页面源码,并用re正则进行正则匹配查找需要的数据. #forex.py#coding:utf-8 ' ...