题目描述

在一个国家里,有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)}的最小值。

输入输出样例

输入样例#1:
复制

5 0 1
1 2 3 4 0
1 1 1 1 1
输出样例#1: 复制

2
输入样例#2: 复制

3 1 1
1 2 0
1 2 3
2
输出样例#2: 复制

1
输入样例#3: 复制

3 1 1
1 2 0
1 2 3
2
输出样例#3: 复制

0
输入样例#4: 复制

10 3 3
0 2 0 0 2 2 8 3 8 7
10 9 1 8 1 3 7 2 8 1
3 4 6
输出样例#4: 复制

3
输入样例#5: 复制

2 0 1
1 0
5 10
输出样例#5: 复制

5

说明

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]城堡的更多相关文章

  1. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  2. BZOJ 1078: [SCOI2008]斜堆

    1078: [SCOI2008]斜堆 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 770  Solved: 422[Submit][Status][ ...

  3. 【BZOJ1076】[SCOI2008]奖励关 状压DP+期望

    [BZOJ1076][SCOI2008]奖励关 Description 你正在玩你最喜欢的电子游戏,并且刚刚进入一个奖励关.在这个奖励关里,系统将依次随机抛出k次宝物,每次你都可以选择吃或者不吃(必须 ...

  4. vijos1059 积木城堡[n年浙江省队第X轮](背包的方案总数 or 01背包)

    描述 XC的儿子小XC最喜欢玩的游戏用积木垒漂亮的城堡.城堡是用一些立方体的积木垒成的,城堡的每一层是一块积木.小XC是一个比他爸爸XC还聪明的孩子,他发现垒城堡的时候,如果下面的积木比上面的积木大, ...

  5. HDU1269 迷宫城堡

    本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...

  6. HD1269迷宫城堡(有向图 && 划分连通块)

    迷宫城堡 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  7. 【bzoj1078】[SCOI2008]斜堆

    2016-05-31 16:34:09 题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1078 挖掘斜堆的性质233 http://www.cp ...

  8. bzoj 3399: [Usaco2009 Mar]Sand Castle城堡

    3399: [Usaco2009 Mar]Sand Castle城堡 Time Limit: 3 Sec  Memory Limit: 128 MB Description 约翰用沙子建了一座城堡.正 ...

  9. hdu 1269 迷宫城堡 强连通分量

    迷宫城堡 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

随机推荐

  1. 搭建vue项目环境

    前言 在开发本项目之前,我对vue,react,angular等框架了解,仅限于知道它们是什么框架,他们的核心是什么,但是并没有实际使用过(angular 1.0版本用过,因为太难用,所以对这类框架都 ...

  2. day-6 机器学习概念及应用

    学习玩Python基础语法,今天开始进行机器学习,首先了解下机器学习和深度学习的一些基本概念和术语: 1.  机器学习概念及应用 2.  深度学习概念及应用 3.  机器学习基本术语及举例 4.  机 ...

  3. 【ASP.NET Core】依赖注入高级玩法——如何注入多个服务实现类

    依赖注入在 ASP.NET Core 中起中很重要的作用,也是一种高大上的编程思想,它的总体原则就是:俺要啥,你就给俺送啥过来.服务类型的实例转由容器自动管理,无需我们在代码中显式处理. 因此,有了依 ...

  4. 一张图说明 Web Api 参数绑定默认规则

    请求如下: 控制器如下: 慎重说明:不管请求方式是 get 还是 post , 简单类型的参数,如 name 和 id ,其值都是从 url 里面去取. Web API 从 url 还是 body 获 ...

  5. Vue.js和jQuery混合使用的一点注意事项

    首先,Vue 的官方是不建议直接操作 DOM 的,其优势在于视图和数据的双向绑定,而且所有DOM操作都可以用Vue实现,反而使用jQuery来操作DOM的话,会造成不必要的麻烦,DOM未渲染完成之前事 ...

  6. Mego开发文档 - 加载关系数据

    加载关系数据 Mego允许您使用模型中的导航属性来加载相关数据对象.目前只支持强制加载数据对象.只有正确配置了关系才能加载关系数据,相关内容可参考关系配置文档. 加载对象属性 您可以使用该Includ ...

  7. 新概念英语(1-129)Seventy miles an hour

    Lesson 129 Seventy miles an hour 时速70英里 Listen to the tape then answer this question. What does Ann ...

  8. SpringCloud的服务注册中心(四)- 高可用服务注册中心的搭建

    一.双 服务注册注册中心 1.服务注册中心的服务端 - EurekaServer 1.1.EurekaServer1 String.application.name=eureka-server ser ...

  9. 云计算(2)it 是什么

    2015年,全世界在it上面的花费达到3亿8千亿美金之多. 云数据中心:核心基础架构,云计算的物理载体,提供数据处理.存储和高性能计算支撑,包括服务器.存储.冷却.机房空间和能耗管理等. 超大规模的云 ...

  10. maven入门(6)maven的生命周期

    1. 三套生命周期     Maven拥有三套相互独立的生命周期,它们分别为clean,default和site. 每个生命周期包含一些阶段,这些阶段是有顺序的,并且后面的阶段依赖于前面的阶段,用户和 ...