关闭

【最短路】NEERC15 F Froggy Ford (Codeforces GYM 100851)

标签: 题解Codeforces图论NEERC最短路
345人阅读 评论(0) 收藏 举报
分类:

题目链接:

  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][2];
double d[N][2];
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=0,r=1,now,to;
	for(i=1;i<=T;i++)d[i][0]=d[i][1]=1e30;
	q[1]=S;d[S][0]=d[S][1]=0;
	while(l!=r)
	{
		now=q[l=(l+1)%N];
		if(now==T)continue;
		u[now]=0;
		if(d[now][0]>d[T][0] && d[now][1]>d[T][1] && d[now][0]>d[T][1])continue;
		for(i=last[now];i;i=a[i].next)
		{
			to=a[i].to;
			if(d[to][0]>max(d[now][0],a[i].dis))
			{
				d[to][0]=max(d[now][0],a[i].dis);
				if(d[now][0]>a[i].dis)f[to][0]=f[now][0];
				else f[to][0]=i;
				if(!u[to])
				{
					u[to]=1;
					if(d[q[(l+1)%N]][0]>d[to][0] && d[q[(l+1)%N]][1]>d[to][1])
						q[l]=to,l=(l+N-1)%N;
					else q[r=(r+1)%N]=to;
				}
			}
			if(d[to][1]>max(d[now][1],a[i].dis))
			{
				d[to][1]=max(d[now][1],a[i].dis);
				f[to][1]=f[now][1];
				if(!u[to])
				{
					u[to]=1;
					if(d[q[(l+1)%N]][0]>d[to][0] && d[q[(l+1)%N]][1]>d[to][1])
						q[l]=to,l=(l+N-1)%N;
					else q[r=(r+1)%N]=to;
				}
			}
			if(d[to][1]>max(d[now][0],a[i].dis/2))
			{
				d[to][1]=max(d[now][0],a[i].dis/2);
				f[to][1]=i;
				if(!u[to])
				{
					u[to]=1;
					if(d[q[(l+1)%N]][0]>d[to][0] && d[q[(l+1)%N]][1]>d[to][1])
						q[l]=to,l=(l+N-1)%N;
					else q[r=(r+1)%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=0;mem(last,0);mem(f,0);mem(u,0);
		scanf("%d",&n);
		S=n+1,T=n+2;p[S].x=p[S].y=p[T].x=p[T].y=0;
		add(S,T,W);
		for(i=1;i<=n;i++)scanf("%d%d",&p[i].x,&p[i].y);
		sort(p+1,p+1+n,cmp);
		for(i=1;i<=n;i++)
		{
			add(S,i,p[i].x);
			add(i,T,W-p[i].x);
		}
		for(i=1;i<n;i++)
		{
			for(j=i+1;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][1]].from;
		k=a[f[T][1]].to;
		if(j==S)p[j].x=0,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/2,y/2);
	}
	return 0;
}
/*
//

//
*/


0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

Gym 100947C——Rotate It !!(水题水题)

Rotate It !! time limit per test 2 seconds memory limit per test 64 megabytes input...
  • say_c_box
  • say_c_box
  • 2016-08-06 22:55
  • 203

codeforces95C 最短路套最短路

题目链接:http://codeforces.com/problemset/problem/95/C 题目大意:城市里面有n个交叉路口,m条路,每条无向有长度,每个交叉路口都有一个出租车司机等待,出租...
  • qq_24477135
  • qq_24477135
  • 2016-06-02 10:53
  • 360

【算法】单源最短路——SPFA

单源最短路除了dijkstra算法之外,还有一种常用的算法叫做SPFA(shortest path faster algorithm)算法,不同于dijkstra的复杂度为o(n^2),SPFA算法的...
  • CFhM_R
  • CFhM_R
  • 2016-03-02 22:52
  • 460

CodeForces - 786B Legacy(线段树 +最短路+思维好题)

Legacy(传送门) 题意 给定nn颗行星,qq次处理,地球位置为ss,求解在qq次处理后,地球到每一颗行星的位置。其中qq有三种不同的操作: 输入v,u,wv,u,w,构建一条从vv到uu的代...
  • qq_18661257
  • qq_18661257
  • 2017-07-20 07:38
  • 333

C++ 基于Dijkstra最短路搜索的Ford Fulkson最大流算法

#include #include #include #include #include using namespace std; const int MAXN = 120; const int ...
  • qq_21555605
  • qq_21555605
  • 2015-06-20 08:32
  • 775

最短路知识点总结(Dijkstra,Floyd,SPFA,Bellman-Ford)

最短路知识点总结(Dijkstra,Floyd,SPFA,Bellman-Ford) Dijkstra算法: 解决的问题:     带权重的有向图上单源最短路径问题。且权重都为非...
  • qq_33406883
  • qq_33406883
  • 2016-07-20 17:55
  • 1363

最短路问题(4种方法)(邻接矩阵,邻接表,bellman-ford,spfa)

以最简单的   Til the Cows Come Home    为例 点击打开链接 几种算法的核心思想就是,先找到距离起点最近的点,以它为松弛点,对所有的点进行松弛操作; 1.dijkstra-...
  • nhl19961226
  • nhl19961226
  • 2017-01-17 11:48
  • 270

[ACM] 最短路算法整理(bellman_ford , SPFA , floyed , dijkstra 思想,步骤及模板)

以杭电2544题目为例 最短路 Problem Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt。但是每当我们的工作人员把上百件的衣服从商店运...
  • sr19930829
  • sr19930829
  • 2014-07-15 16:14
  • 2252

蓝桥杯 - 算法训练 最短路 Bellman-Ford算法 C语言实现

蓝桥杯 算法提高训练 最短路径 问题描述 给定一个n个顶点,m条边的有向图(其中某些边权可能为负,但保证没有负环)。请你计算从1号点到其他点的最短路(顶点从1到n编号)。 输入格式 第一行两个整...
  • qq_34845121
  • qq_34845121
  • 2017-02-12 00:03
  • 744

bellman-ford算法——最短路问题,判断是否存在负权回路或正权回路

转载链接:http://www.wutianqi.com/?p=1912 Dijkstra算法是处理单源最短路径的有效算法,但它局限于边的权值非负的情况,若图中出现权值为负的边,...
  • ZQUSwansea
  • ZQUSwansea
  • 2015-11-09 10:37
  • 1060
    个人资料
    • 访问:72732次
    • 积分:2452
    • 等级:
    • 排名:第17439名
    • 原创:243篇
    • 转载:2篇
    • 译文:0篇
    • 评论:17条
    文章分类
    最新评论