标签:注意 nbsp ++ while 学习 output typedef cond clu
BZOJ_1975_[Sdoi2010]魔法猪学院_A*
3
题意很明确,问最多能跑几次,其实就是K短路,每次判断长度和生育能量的大小即可。
K短路这里使用A*(可持久化可并堆做法挖坑代填)
估价函数设置为当前走过的距离+最短到终点的距离。
最短到终点的距离用dij预处理出来。
代码:
#include <stdio.h> #include <string.h> #include <algorithm> #include <stdlib.h> #include <ext/pb_ds/priority_queue.hpp> using namespace std; using namespace __gnu_pbds; inline int rd() { register int x=0; register char s=getchar(); while(s<‘0‘||s>‘9‘) s=getchar(); while(s>=‘0‘&&s<=‘9‘) x=(x<<3)+(x<<1)+s-‘0‘,s=getchar(); return x; } typedef double f2; #define N 5050 #define M 200050 int head[N],to[M],nxt[M],cnt,n,m,xx[M],yy[M],vis[N],tot[N],ans; f2 val[M],zz[M],dis[N],lft; __attribute__((optimize("-O2")))struct node { f2 v; int x; node() {} node(f2 v_,int x_) : v(v_),x(x_) {} inline bool operator < (const node &u) const { return v+dis[x]>u.v+dis[u.x]; } }; __gnu_pbds::priority_queue<pair<f2,int> >q1; __gnu_pbds::priority_queue<node>q2; __attribute__((optimize("-O2")))inline void add(int u,int v,f2 w) { to[++cnt]=v; nxt[cnt]=head[u]; head[u]=cnt; val[cnt]=w; } __attribute__((optimize("-O2")))void dij() { memset(dis,0x7f,sizeof(dis)); dis[n]=0; q1.push(make_pair(0,n)); while(!q1.empty()) { int x=q1.top().second,i; q1.pop(); if(vis[x]) continue; vis[x]=1; for(i=head[x];i;i=nxt[i]) { if(dis[to[i]]>dis[x]+val[i]) { dis[to[i]]=dis[x]+val[i]; q1.push(make_pair(-dis[to[i]],to[i])); } } } } __attribute__((optimize("-O2")))void _A_stAr_SapPh1r3_() { f2 inf=lft/dis[1]; q2.push(node(0,1)); while(!q2.empty()) { node t=q2.top(); q2.pop(); int x=t.x; f2 v=t.v; // printf("%f\n",lft); int i; if(x==n) { if(lft>=v) { lft-=v; ans++; }else { printf("%d\n",ans); exit(0); } } for(i=head[x];i;i=nxt[i]) { q2.push(node(v+val[i],to[i])); } } } __attribute__((optimize("-O2")))int main() { n=rd(); m=rd(); scanf("%lf",&lft); int i; for(i=1;i<=m;i++) { xx[i]=rd(); yy[i]=rd(); scanf("%lf",&zz[i]); add(yy[i],xx[i],zz[i]); } dij(); //lft/=dis[1]; memset(head,0,sizeof(head)); cnt=0; for(i=1;i<=m;i++) { add(xx[i],yy[i],zz[i]); } _A_stAr_SapPh1r3_(); printf("%d\n",ans); }
标签:注意 nbsp ++ while 学习 output typedef cond clu
原文地址:https://www.cnblogs.com/suika/p/9062431.html