大致题意:
给出一个100*100的池塘,池塘中心位于二维坐标原点。池塘中心有一个直径为15的圆形岛屿,一个人站在岛屿上。给出池塘中n个小岛的位置和这个人的最大步长。求这个人想到池塘对岸的话最少要走多长的距离,最少要迈多少步。
大致思路:
把小岛抽象为起点,对岸抽象为终点,求最短路即可。最短路的思路很好想到,但是需要精度控制的经验啊。
#include<iostream>
#include<cmath>
#include<cstdio>
#include<fstream>
#include<cstring>
using namespace std;
const int nMax=100050;
const int mMax=1000050;
const int inf=1<<30;
const double eps=1e-12;
struct{
int v, next;
double w;
}edge[mMax];
int n,k,edgeHead[nMax];
double dis[nMax];
int stack[nMax],m;
bool vis[nMax];
int steps[nMax];
void addedge(int a,int b,double w){
edge[k].w = w;
edge[k].v=b;
edge[k].next=edgeHead[a];
edgeHead[a]=k;k++;
}
int spfa(int s){
int i, top = 0;
memset(vis,0,sizeof(vis));
for(i=1;i<=n;i++){
dis[i]=inf;
steps[i]=inf;
}
dis[s]=steps[s]=0;
stack[++top]=s;
vis[s]=true;
while(top){
int u=stack[top--];
vis[u]=false; /////////////////
for(i=edgeHead[u];i!=0;i=edge[i].next){
int v=edge[i].v;
if(abs(dis[v]-(dis[u]+edge[i].w))<=eps){
if(steps[v]>steps[u]+1){
steps[v]=steps[u]+1;
if(!vis[v]){
vis[v]=true;
stack[++top]=v;
}
}
continue;
}
if(dis[v]>dis[u]+edge[i].w){
dis[v]=dis[u]+edge[i].w;
steps[v]=steps[u]+1;
if(!vis[v]){
vis[v]=true;
stack[++top] = v;
}
}
}
}
int sum=0;
for(i=1;i<=n;i++){
sum+=dis[i];
}
return sum;
}
class fuck{
public:
int x,y;
}node[nMax];
int len;
double getdis(int a,int b){
return sqrt((node[a].x-node[b].x)*(node[a].x-node[b].x)+(node[a].y-node[b].y)*(node[a].y-node[b].y));
}
int main(){
int i,j,s,t;
double d,e;
node[0].x=node[0].y=0;
// freopen("gift.in","r",stdin);
while(scanf("%d%d",&n,&len)!=EOF){
k=1;
memset(edgeHead,0,sizeof(edgeHead));
for(i=1;i<=n;i++){
scanf("%d%d",&node[i].x,&node[i].y);
}
for(i=1;i<=n;i++){
for(j=1;j<=n;j++){
if(i==j)continue;
d=getdis(i,j);
// cout<<d<<endl;
if(d<=len){
addedge(i,j,d);
}
}
}
s=n+1;
t=n+2;
for(i=1;i<=n;i++){
d=getdis(0,i)-7.5;
if(d<=len){
addedge(s,i,d);
}
d=min(50-node[i].x,50-node[i].y);
e=min(node[i].x+50,node[i].y+50);
d=min(d,e);
if(d<=len){
addedge(i,t,d);
}
}
n+=2;
spfa(s);
if(fabs(dis[t]-inf)<=eps){
printf("can't be saved\n");
continue;
}
printf("%.2f %d\n",dis[t],steps[t]);
}
return 0;
}
分享到:
相关推荐
设施选址算法模型:spfa+最小费用最大流+(二进制粒子群优化算法量子行为粒子群优化算法遗传算法_CodeCraft
SPFA import java.util.Arrays; import java.util.LinkedList; import java.util.Queue; import java.util.Scanner; public class SPFA { static SE[] e = new SE[9999]; static int[] dis = new int[9999]; ...
标题中的"SPFA.zip_SPFA"表明这是一个与SPFA算法相关的压缩文件,SPFA全称为Shortest Path Faster Algorithm,即最短路径更快算法。这是一种解决图论中的单源最短路径问题的算法,通常用于有向图。描述提到SPFA算法...
C++ SPFA算法 SPFA(Shortest Path Faster Algorithm)是一种求解单源最短路径问题的算法,它可以在O(kE)的时间复杂度内求出源点到其他所有点的最短路径,并且可以处理负边。该算法的基本思想是使用一个队列来维护...
SPFA(Shortest Path Faster Algorithm)算法是一种求解图中单源最短路径问题的算法,它是Bellman-Ford算法的一种优化版本。在Java中实现SPFA算法,我们需要理解其核心思想并熟悉Java编程语法。 SPFA算法的主要优点...
SPFA(Shortest Path Faster Algorithm)是最短路径算法的一种,主要应用于图论和网络流问题中,用于寻找从源节点到图中所有其他节点的最短路径。SPFA算法是Bellman-Ford算法的一种优化版本,它在处理负权边的情况下...
"SPFA算法优化及应用" SPFA(Shortest Path Faster Algorithm)是一种高效的单源最短路算法,广泛应用于图论和动态规划等领域。下面是对SPFA算法的详细介绍和优化。 基本实现 SPFA算法的基本思想是通过relax操作...
标题中的"SPFA.rar_SPFA_problem solving"指出我们要探讨的是一个与SPFA算法相关的问题解决过程。SPFA,即Shortest Path Faster Algorithm(最短路径更快算法),是用于解决图论中的单源最短路径问题的一种算法。它...
SPFA(Shortest Path Faster Algorithm)算法是一种基于队列的数据结构优化版的Bellman-Ford算法,主要用于解决图论中的单源最短路径问题。它在处理稀疏矩阵时表现出较高的效率,尤其适用于边数量远小于顶点数量平方...
【SPFA算法详解】 SPFA(Shortest Path Faster Algorithm)是一种用于解决图中单源最短路径问题的算法,由段凡丁在1994年提出。它采用了动态优化逼近的思想,相比于经典的Dijkstra算法,在某些情况下表现出更好的...
SPFA(Shortest Path Faster Algorithm)算法是一种用于解决图论中的单源最短路径问题的算法,它是贝尔曼-福特(Bellman-Ford)算法的一种优化版本,主要应用于求解带有负权重边的图的最短路径。SPFA通过使用队列...
**SPFA算法详解** SPFA(Shortest Path Faster Algorithm)是一种用于解决图论中的单源最短路径问题的算法,由姚一兆提出。相比于Dijkstra算法,SPFA在处理某些稠密图时表现出更高的效率,尽管它不是一种确定性的...
这里是SPFA的源代码
SPFA最短路径算法 SPFA(Shortest Path Faster Algorithm)是一种单源最短路径算法,它的性能非常好,代码实现也并不复杂。特别是当图的规模大,用邻接矩阵存不下的时候,用 SPFA 则可以很方便地面对临接表。每个...
**SPFA算法详解** SPFA(Shortest Path Faster Algorithm)是一种用于解决图论中的单源最短路径问题的算法,由姚新在2001年提出。它是一种改进的Bellman-Ford算法,旨在提高求解效率。与Bellman-Ford算法每次迭代...
**SPFA算法详解** SPFA(Shortest Path Faster Algorithm,最短路径更快算法)是一种用于解决图论中的单源最短路径问题的算法,由美国伊利诺伊大学香槟分校的王浩教授提出。与Dijkstra算法不同,SPFA算法在某些情况...
SPFA[知乎:叶枝黎曼].py
最短路SPFA算法。SPFA(Shortest Path Faster Algorithm)算法是求单源最短路径的一种算法,它是Bellman-ford的队列优化,它是一种十分高效的最短路算法。存在负权边时使用。