【最短路】NEERC15 F Froggy Ford(2015-2016 ACM-ICPC)(Codeforces GYM 100851)
题目链接:
http://codeforces.com/gym/100851
题目大意:
一只青蛙跳过宽为W的河,河中游N个石头,坐标xi,yi,现在往河中间添加一个石头,使得每次跳跃的最大的距离最小。求这个添加的石头的位置。
题目思路:
【最短路】
设置源汇S,T,S到T连一条W的边,S到每个点连Xi的边,每个点到T连W-Xi的边。每个点往其他点连一条Di,j的边(直线距离)
统计到每个点的最大跳跃距离d[i][0],d[i][1],0表示没有加过石子,1表示加过。同时记录这个答案是由哪一条边更新的。
三种转移d[u][0]->d[v][0],d[u][0]->d[v][1],d[u][1]->d[v][1]。
最后答案就是更新d[T][1]的那条边的终点。
//
//by coolxxx
//#include<bits/stdc++.h>
#include<iostream>
#include<algorithm>
#include<string>
#include<iomanip>
#include<map>
#include<stack>
#include<queue>
#include<set>
#include<bitset>
#include<memory.h>
#include<time.h>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
//#include<stdbool.h>
#include<math.h>
#define min(a,b) ((a)<(b)?(a):(b))
#define max(a,b) ((a)>(b)?(a):(b))
#define abs(a) ((a)>0?(a):(-(a)))
#define lowbit(a) (a&(-a))
#define sqr(a) ((a)*(a))
#define swap(a,b) ((a)^=(b),(b)^=(a),(a)^=(b))
#define mem(a,b) memset(a,b,sizeof(a))
#define eps (1e-8)
#define J 10
#define mod 1000000007
#define MAX 0x7f7f7f7f
#define PI 3.14159265358979323
#define N 1004
#define M 2100004
using namespace std;
typedef long long LL;
int cas,cass;
int n,m,lll,ans;
int W,S,T;
int fa[N],last[N],q[N],f[N][];
double d[N][];
bool u[N];
struct Point
{
int x,y;
}p[N];
struct xxx
{
int from,to,next;
double dis;
}a[M];
void add(int x,int y,double z)
{
a[++lll].next=last[x];
a[lll].from=x;
a[lll].to=y;
a[lll].dis=z;
last[x]=lll;
}
bool cmp(Point aa,Point bb)
{
if(aa.x!=bb.x)return aa.x>bb.x;
return aa.y>bb.y;
}
void spfa()
{
int i,l=,r=,now,to;
for(i=;i<=T;i++)d[i][]=d[i][]=1e30;
q[]=S;d[S][]=d[S][]=;
while(l!=r)
{
now=q[l=(l+)%N];
if(now==T)continue;
u[now]=;
if(d[now][]>d[T][] && d[now][]>d[T][] && d[now][]>d[T][])continue;
for(i=last[now];i;i=a[i].next)
{
to=a[i].to;
if(d[to][]>max(d[now][],a[i].dis))
{
d[to][]=max(d[now][],a[i].dis);
if(d[now][]>a[i].dis)f[to][]=f[now][];
else f[to][]=i;
if(!u[to])
{
u[to]=;
if(d[q[(l+)%N]][]>d[to][] && d[q[(l+)%N]][]>d[to][])
q[l]=to,l=(l+N-)%N;
else q[r=(r+)%N]=to;
}
}
if(d[to][]>max(d[now][],a[i].dis))
{
d[to][]=max(d[now][],a[i].dis);
f[to][]=f[now][];
if(!u[to])
{
u[to]=;
if(d[q[(l+)%N]][]>d[to][] && d[q[(l+)%N]][]>d[to][])
q[l]=to,l=(l+N-)%N;
else q[r=(r+)%N]=to;
}
}
if(d[to][]>max(d[now][],a[i].dis/))
{
d[to][]=max(d[now][],a[i].dis/);
f[to][]=i;
if(!u[to])
{
u[to]=;
if(d[q[(l+)%N]][]>d[to][] && d[q[(l+)%N]][]>d[to][])
q[l]=to,l=(l+N-)%N;
else q[r=(r+)%N]=to;
}
}
}
}
}
int main()
{
#ifndef ONLINE_JUDGE
// freopen("froggy.in","r",stdin);
// freopen("froggy.out","w",stdout);
#endif
int i,j,k;
double x,y,z;
// for(scanf("%d",&cass);cass;cass--)
// for(scanf("%d",&cas),cass=1;cass<=cas;cass++)
// while(~scanf("%s",s+1))
while(~scanf("%d",&W))
{
lll=;mem(last,);mem(f,);mem(u,);
scanf("%d",&n);
S=n+,T=n+;p[S].x=p[S].y=p[T].x=p[T].y=;
add(S,T,W);
for(i=;i<=n;i++)scanf("%d%d",&p[i].x,&p[i].y);
sort(p+,p++n,cmp);
for(i=;i<=n;i++)
{
add(S,i,p[i].x);
add(i,T,W-p[i].x);
}
for(i=;i<n;i++)
{
for(j=i+;j<=n;j++)
{
z=sqrt(1LL*(p[i].x-p[j].x)*(p[i].x-p[j].x)+1LL*(p[i].y-p[j].y)*(p[i].y-p[j].y));
if(z>W)continue;
add(i,j,z);
add(j,i,z);
}
}
spfa();
j=a[f[T][]].from;
k=a[f[T][]].to;
if(j==S)p[j].x=,p[j].y=p[k].y;
if(k==T)p[k].x=W,p[k].y=p[j].y;
x=1LL*(p[j].x+p[k].x);
y=1LL*(p[j].y+p[k].y);
printf("%lf %lf\n",x/,y/);
}
return ;
}
/*
// //
*/
【最短路】NEERC15 F Froggy Ford(2015-2016 ACM-ICPC)(Codeforces GYM 100851)的更多相关文章
- HDU 5876 Sparse Graph 【补图最短路 BFS】(2016 ACM/ICPC Asia Regional Dalian Online)
Sparse Graph Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)To ...
- HDU 5889 Barricade 【BFS+最小割 网络流】(2016 ACM/ICPC Asia Regional Qingdao Online)
Barricade Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total S ...
- 2016 ACM/ICPC Asia Regional Dalian Online 1006 /HDU 5873
Football Games Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)To ...
- HDU 5874 Friends and Enemies 【构造】 (2016 ACM/ICPC Asia Regional Dalian Online)
Friends and Enemies Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Othe ...
- HDU 5875 Function 【倍增】 (2016 ACM/ICPC Asia Regional Dalian Online)
Function Time Limit: 7000/3500 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- HDU 5873 Football Games 【模拟】 (2016 ACM/ICPC Asia Regional Dalian Online)
Football Games Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)To ...
- 2016 ACM/ICPC Asia Regional Qingdao Online(2016ACM青岛网络赛部分题解)
2016 ACM/ICPC Asia Regional Qingdao Online(部分题解) 5878---I Count Two Three http://acm.hdu.edu.cn/show ...
- 2016 ACM/ICPC亚洲区青岛站现场赛(部分题解)
摘要 本文主要列举并求解了2016 ACM/ICPC亚洲区青岛站现场赛的部分真题,着重介绍了各个题目的解题思路,结合详细的AC代码,意在熟悉青岛赛区的出题策略,以备战2018青岛站现场赛. HDU 5 ...
- 2016 ACM ICPC Asia Region - Tehran
2016 ACM ICPC Asia Region - Tehran A - Tax 题目描述:算税. solution 模拟. B - Key Maker 题目描述:给出\(n\)个序列,给定一个序 ...
随机推荐
- .NET中TextBox控件设置ReadOnly=true后台取不到值三种解决方法
当TextBox设置了ReadOnly=true后要是在前台为控件添加了值,后台是取不到的,值为空,多么郁闷的一个问题经过尝试,发现可以通过如下的方式解决这个问题.感兴趣的朋友可以了解下 当TextB ...
- partial局部类
局部类型允许我们将一个类.接口或结构分成好几个部分,分别实现在几个不同的.cs文件中. 局部类型适用于以下情况: (1)类型特别大,不宜放在一个文件中实现. (2)一个类型中的一部分代码为自动化工具生 ...
- (转)ecshop产品详情页显示不清晰
详情页面的商品图片的设置方法 后台商店设置-显示设置-显示设置(就是这里,商品图片宽度和高度设置的大点就行了,放大镜效果也清晰了) 按照您详情页面图片的实际显示大小来添写. 商品管理-图片批量处理,这 ...
- windows Server 2008 -必须使用“角色管理工具”安装或配置Microsoft .Net Framework 3.5
在windows Server 2008上安装 .Net Framework 3.5的时候,报错:必须使用“角色管理工具”安装或配置Microsoft .Net Framework 3.5. Solu ...
- 解决Xcode7多个模拟器的方法
xcode模拟器都这样显示,没办法判断是哪个系统,解决办法是 1.关闭xcode 2.终端输入 sudo killall -9 com.apple.CoreSimulator.CoreSimulato ...
- Android 学习手札(一) 应用程序架构
1.资源列表 Android支持的资源列表 目 录 资源类型 描述 res/anim XML 该目录用于存放帧(frame).动画或补间(tweened)动画文件 res/drawable ...
- win7访问windows server 2003服务器出现未知的用户名或者错误的密码(转载)
直接放答案,感谢网友提供答案,否则自已还一直在纳闷,为什么? win7系统的安全机制限制了登陆.只要系统时间和win2003服务器的系统时间相差很多,系统就会阻止其登陆,并显示错误信息:"未 ...
- 反射给对象赋值遇到的问题——类型转换[转http://blog.csdn.net/xiaohan2826/article/details/8536074]
发布时间:2012-10-25 10:49浏览次数:225 给一个对象属性赋值可以通过PropertyInfo.SetValue()方式进行赋值,但要注意值的类型要与属性保持一致. 创建对象实例的 ...
- Shell 控制并发
方法1: #!/bin/bash c=0 for i in `seq -w 18 31`;do while [ $c -ge 3 ];do c=$(jobs -p |wc -w) sleep 1s d ...
- windows server 2008 asp连接数据库sql2000失败
由于服务器现在的服务器已不能承受了,需要替换服务器并把window2003升级为window2008,把所有数据都平移过来.平移完后遇到ASP总是不能连接上sql2000,这让我非常郁闷,处理了好几个 ...