题目链接:

  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)的更多相关文章

  1. 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 ...

  2. 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 ...

  3. 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 ...

  4. 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 ...

  5. 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 ...

  6. 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 ...

  7. 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 ...

  8. 2016 ACM/ICPC亚洲区青岛站现场赛(部分题解)

    摘要 本文主要列举并求解了2016 ACM/ICPC亚洲区青岛站现场赛的部分真题,着重介绍了各个题目的解题思路,结合详细的AC代码,意在熟悉青岛赛区的出题策略,以备战2018青岛站现场赛. HDU 5 ...

  9. 2016 ACM ICPC Asia Region - Tehran

    2016 ACM ICPC Asia Region - Tehran A - Tax 题目描述:算税. solution 模拟. B - Key Maker 题目描述:给出\(n\)个序列,给定一个序 ...

随机推荐

  1. 【Android】android镜像翻转

    Android镜像翻转指的是将屏幕进行水平的翻转,达到所有内容显示都会反向的效果,就像是在镜子中看到的界面一样.这种应用的使用场景相对比较受限,主要用在一些需要使用Android手机界面进行镜面投影的 ...

  2. HDFS的Java客户端操作代码(查看HDFS下所有的文件或目录)

    1.查看HDFS下所有的文件或目录 package Hdfs; import java.io.IOException; import java.net.URI; import org.apache.h ...

  3. widows sever2003 PHP环境搭建

    此文仅为文字笔记,非原创,摘阅自互联网  1.安装IIS6.0及Framework 2.0  2.安装fastcgi http://www.iis.net/download/FastCGI 安装fas ...

  4. JavaScript Math对象

    Math对象是JavaScript的一个固有对象,其作用是执行常见的算数任务.该对象的使用并不是像Date,Array对象使用 new关键字来得到对象,而是直接 Math.[{property|met ...

  5. 佳博GprinterApp编辑软件使用说明

    佳博打印机代理商淘宝店https://shop107172033.taobao.com/index.htm?spm=2013.1.w5002-9520741823.2.Sqz8Pf 在此店购买的打印机 ...

  6. 文字排版--下划线(text-decoration:underline)

    <!DOCTYPE HTML> <html> <head> <meta http-equiv="Content-Type" content ...

  7. iOS中常用的正则表达式

    iOS常用正则表达式 正则表达式用于字符串处理.表单验证等场合,实用高效.现将一些常用的表达式收集于此,以备不时之需. 匹配中文字符的正则表达式: [\u4e00-\u9fa5]评注:匹配中文还真是个 ...

  8. 【转】jquery两稳定版本比较~~

    博客分类: Web前端 jquery  jquery历经了多个版本的更新,版本上的比较貌似没什么必要性,一般来说新的版本会比旧的版本各方面都略有提升,但由于新版中增加了各种新的功能,难免会引起bug的 ...

  9. Oauth认证简介

    Oauth是什么: 1.Oauth是一种安全认证的协议: 2.Oauth为用户资源的授权提供了一个安全的.开放而又简易的标准: 3.Oauth的授权不会使第三方触及到用户的账号信息(用户名和密码). ...

  10. Java jdk环境搭建

    java JDK的配置在我的电脑环境变量中配置: 主要的配置参数path  例:path = C:\jdk1.7.0_13\bin ; 另外一个JAVA_HOME 例:JAVA_HOME = C:\j ...