soj115 御坂网络
题意:平面上有n个A发射点和m个B发射点,可以选择安置相应A/B装置,装置范围是圆,自取半径(要求都相同且<=Rmax)。异种要求范围不相交。求装置范围之和(不是并!)。
标程:
#include<bits/stdc++.h>
using namespace std;
const int N=;
const int inf=0x3f3f3f3f;
typedef long long ll;
int cnt=,n,m,ans,Rx,xa[N],xb[N],yb[N],ya[N],head[N],Head[N],tot,S,T,dis[N];
ll Ans;
queue<int> q;
bitset<N> f[N];
struct node{int to,next,f;}num[N*N];
struct Node{int d,x,y;Node(){} Node(int A,int B,int C){d=A;x=B;y=C;}}p[N*N];
void add(int x,int y,int w)
{
num[++cnt].to=y;num[cnt].next=head[x];num[cnt].f=w;head[x]=cnt;
num[++cnt].to=x;num[cnt].next=head[y];num[cnt].f=;head[y]=cnt;
if (!f[x][y])
for (int i=;i<=T;i++) if (f[i][x]&&!f[i][y]) f[i]|=f[y];
}
void init()
{
for (int i=;i<=T;i++) f[i].reset(),f[i][i]=;
for (int i=;i<=T;i++)
for (int j=head[i];j;j=num[j].next)
if (num[j].f) f[i][num[j].to]=;
for (int i=;i<=T;i++)
for (int j=;j<=T;j++) if (f[i][j]) f[i]|=f[j];
}
int bfs()
{
memset(dis,,sizeof(dis));dis[S]=;q.push(S);
while (!q.empty())
{
int now=q.front();q.pop();
for (int i=head[now];i;i=num[i].next)
if (num[i].f&&!dis[num[i].to]) dis[num[i].to]=dis[now]+,q.push(num[i].to);
}
return dis[T];
}
int dfs(int x,int Min)
{
int tmp=Min;
if (x==T||!Min) return Min;
for (int &i=Head[x];i&&tmp;i=num[i].next)
if (dis[num[i].to]==dis[x]+)
{
int t=dfs(num[i].to,min(tmp,num[i].f));
num[i].f-=t;num[i^].f+=t;tmp-=t;
}
return Min-tmp;
}
int dinic()
{
if (!f[S][T]) return ;
int res=,tmp;
while (bfs())
{
memcpy(Head,head,sizeof(head));
while (tmp=dfs(S,inf)) res+=tmp;
}
init();
return res;
}
int get_dis(int i,int j){return (xa[i]-xb[j])*(xa[i]-xb[j])+(ya[i]-yb[j])*(ya[i]-yb[j]);}
bool cmp(const Node &A,const Node &B){return A.d<B.d;}
int main()
{
scanf("%d%d%d",&n,&m,&Rx);S=n+m+;T=S+;
for (int i=;i<=T;i++) f[i][i]=;
for (int i=;i<=n;i++) add(S,i,);
for (int i=;i<=m;i++) add(i+n,T,);
for (int i=;i<=n;i++) scanf("%d",&xa[i]);
for (int i=;i<=n;i++) scanf("%d",&ya[i]);
for (int i=;i<=m;i++) scanf("%d",&xb[i]);
for (int i=;i<=m;i++) scanf("%d",&yb[i]);
for (int i=;i<=n;i++)
for (int j=;j<=m;j++) p[++tot]=Node(get_dis(i,j),i,j);
p[++tot]=Node(Rx*Rx*,,);
sort(p+,p+tot+,cmp);
for (int i=;i<=tot&&p[i].d<=Rx*Rx*;i++)//从0开始,有可能
{
add(p[i].x,p[i].y+n,);
if (p[i].d!=p[i+].d) ans+=dinic(),Ans=max(Ans,min((ll)max(p[i+].d,p[i].d),Rx*Rx*4ll)*(n+m-ans));//注意取后一个半径进行运算,注意边界!
}
printf("%.4lf\n",(double)Ans*M_PI*0.25);
return ;
}
易错点:1.注意统计圆半径是已连边半径的后一个。因此需要从没有圆冲突的半径开始算。
2.一开始以为是圆半径不相同。题目又又又看错了啊。可能是太久没写题了。
题解:枚举半径+网络流匹配+传递闭包优化
如果某A和某B之间的距离为dis,那么如果取半径>dis/2,该A和该B之间只能取其一。
枚举关键半径n^2。只能取其一,即求最大独立集。我们想到了可以二分图匹配n^3(而边权为1用dinic可以做到n^2.5)。O(n^4.5)。
结束。
用传递闭包在每次网络流结束后统计S到T的可达情况。下一次进去的时候若S->T不可达,那么return 0。这样最多进行n次网络流,bitset优化一下:O(n*(n^3/w+n^2.5))。
soj115 御坂网络的更多相关文章
- Wannafly挑战赛29-A御坂美琴 (dfs+map)
链接:https://ac.nowcoder.com/acm/contest/271/A来源:牛客网 御坂美琴 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 131072K,其他语言 ...
- Wannafly挑战赛29A御坂美琴
传送门 这套题很有意思2333 蠢了--首先先判总共加起来等不等于\(n\),不是的话就不行 然后dfs记录\(n\)不断分下去能分成哪些数,用map记录一下,判断是否所有数都能被分出来就是了 //m ...
- Wannafly挑战赛26题解
为啥混进了几道不是魔禁的题--出题人太不敬业了-- 传送门 \(A\) 御坂网络 为啥没有番外个体和整体意志呢 暴力模拟就好了,这个要是都打错我干脆滚回去学文化课算了 //minamoto #incl ...
- 如何优雅的进入IT世界
原始地址:http://www.cocoachina.com/gamedev/misc/2014/0613/8808.html 以下三段是废话,请跳过. (废话段1)有文科生想了解IT世界.这并不 ...
- 什么是A站、B站、C站、D站、E站、F站、G站、HIJKLM站N站?
A站AcFun弹幕视频网,简称“A站”,成立于2007年6月,取意于Anime Comic Fun,是中国大陆第一家弹幕视频网站.A站以视频为载体,逐步发展出基于原生内容二次创作的完整生态,拥有高质量 ...
- 魔法禁书目录2:回家(codevs 3024)
题目描述 Description 大妈打完三战回家,我知道他是怎么回来的,欧洲到日本有L个站点他决定乘坐恰好n次飞机(不是学院都市的超音速飞机)和m次火车来从第一个站点到达最后一个站点.但是有一点很重 ...
- 洛谷P2264 情书
P2264 情书 88通过 971提交 题目提供者lin_toto 标签字符串 难度提高+/省选- 提交该题 讨论 题解 记录 最新讨论 yyy快把题目改回来 噫 这题的题目好逗啊... 情书std ...
- [bilibili]弹幕屏蔽列表
<filters> <item enabled="true">t=定单身</item> <item enabled="true& ...
- CCPC-Wannafly Winter Camp Day8 (Div2, onsite)
咕咕咕. camp补题. 传送门:https://www.zhixincode.com/contest/29/problems A.Aqours 题意:有一棵有根树,根节点为1,给出每个结点的父 ...
随机推荐
- [已解决]报错:execjs._exceptions.ProgramError: ReferenceError: window is not defined
问题: execjs._exceptions.ProgramError: ReferenceError: window is not defined 解决: 定义一个就行 var window = { ...
- html5本地存储(一)------ web Storage
在html5中与本地存储相关的两个相关内容:Web Storage 与本地数据库 web Storage存储机制是对html4中的cookie存储机制的一个改善.web Storage就是在web上 ...
- JAVA里面的int类型 和Integer类型,有什么不一样
JAVA里面的int类型 和Integer类型,有什么不一样 原创 2013年09月04日 23:15:11 标签: java / 2120 编辑 删除 JAVA里面的int类型 和Integer类型 ...
- 如何实现qq消息轰炸
1.新建一个文本文档复制以下代码 Set WshShell = WScript.CreateObject("Wscript.Shell")WshShell.AppActivate& ...
- vim 中 ctags的应用
为了方便查询代码段中代码的最终的定义 在linux的vim便以其中可以使用ctags 使用步骤: 1. 安装 ctags : sudo apt-get install ctags 2. 生 ...
- Mysql ibd恢复
一,binlog恢复,这里就不说了. 二,ibd方式其实很简单, 生成数据结构(有的可以跳过) 1,创建一个新库 2,新库里新建一个表,名字和回复的表一样. 字段数量一样(字段类型和名字都无所谓) 3 ...
- centos7.x部署php7.0、mysql
1.安装httpd yum install httpd systemctl start httpd.service #启动命令 systemctl stop httpd.service #停止命令 s ...
- Spring常见面试题及答案解析
.说一下spring中Bean的作用域 singleton: Spring IoC容器中只会存在一个共享的Bean实例,无论有多少个Bean引用它,始终指向同一对象.Singleton作用域是Spri ...
- Redis缓存数据库简单介绍
\ 1.什么是redis redis是一种基于内存的高性能键值型数据库(key-value),属于NoSQL,和 Memcached 类似: 从内存读取速度为110000次/s,写入内存速度为8100 ...
- 基于javaweb人脸识别注册登录系统
---恢复内容开始--- 现在是2019年,人脸识别技术已经相当成熟了,百度自2017年发布人脸识别技术,已经被广泛应用,不管从现在的iphoneX掀起的面部解锁到手机应用端的各种人脸认证,这一技术已 ...