【最短路】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\)个序列,给定一个序 ...
随机推荐
- QT Windows下生成动态链接库
目标:需要将一个QT程序生成动态链接库 Windows环境下Qt生成的共享库文件其后缀为dll,可以在程序运行过程中动态加载 新建项目,选择库 选择共享库 建立好项目后生成三个文件,两个.h一个.cp ...
- WisDom.Net 框架设计(一) 总体框架
WisDom.Net总体框架 1.目标 WisDom.Net 做为以后快速开发相关的软件的基础框架,实现用户,权限,角色,菜单,和工作流的管理功能.相关功能可以独立使用,快速用于其他程序的开发.预计 ...
- reflact中GetMethod方法的使用
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.R ...
- Eclipse vs IDEA快捷键对比大全(win系统)
花了几天时间熟悉IDEA的各种操作,将各种快捷键都试了一下,感觉很是不错! 以下为我整理了一下开发过程中经常用的一些Eclipse快捷键与IDEA的对比,方便像我一样使用Eclipse多年但想尝试些改 ...
- 受限玻尔兹曼机(RBM)
能量模型 RBM用到了能量模型. 简单的概括一下能量模型.假设一个孤立系统(总能量$E$一定,粒子个数$N$一定),温度恒定为1,每个粒子有$m$个可能的状态,每个状态对应一个能量$e_i$.那么,在 ...
- 更新xcode后插件失效问题——不针对特定版本的通用解决方法
一.Xcode更新后插件失效的原理 1.每次更新Xcode后插件都会失效,其实插件都还在这个目录好好的躺着呢: ~/Library/Application Support/Developer/Shar ...
- Spring 中的注解
1.普通方式注解 a.在配置文件中配置 1.导入命名空间 xmlns:context="http://www.springframework.org/schema/ ...
- 读终端输入数据BufferedReader
public static void main(String[] args) { BufferedReader br=new BufferedReader(new InputStream ...
- dede列表标签递增数字生成
今天给人家调试程序,用到[field:global name=autoindex/ ] 调用指定频道.而频道前面需要加CSS代码,CSS代码正好是按序号排列的 忽然发现,是从0开始. 于是修改了一下代 ...
- php字符串处理函数常见问题
PHP 的字符串处理功能非常强大,主要包括: 字符串输出 echo():输出一个或多个字符串 print():输出一个字符串 printf():输出格式化字符串 字符串去除 trim():去除字符串 ...