SPFA时点出队后一定要把在队内的标记置为false!SPFA时点出队后一定要把在队内的标记置为false!SPFA时点出队后一定要把在队内的标记置为false!

我因为这个卡了一个月大家信吗?测得时候总是60分,丢情况,总之我太弱了

一个月前傻傻的手写堆o(>﹏<)o,现在写Yveh教的我的stl大法的优先队列用于A*爽的飞起\(≧▽≦)/

#include<queue>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int point[5003],next[200003],v[200003],point2[5003],next2[200003],v2[200003],cnt=0,cnt2=0,N,M;
double c[200003],c2[200003],dist[5003],E;
bool p[5003];
struct datatype{
double g; int isk;
bool operator < (const datatype &a) const
{
return g+dist[isk]>a.g+dist[a.isk];
}
};
void insect(int x,int y,double z){next[cnt]=point[x];point[x]=cnt;v[cnt]=y;c[cnt]=z;cnt++;}
void insect2(int x,int y,double z){next2[cnt2]=point2[x];point2[x]=cnt2;v2[cnt2]=y;c2[cnt2]=z;cnt2++;}
void SPFA()
{
p[N]=1; queue<int>Q;Q.push(N); dist[N]=0.0; int i,now;
while (!Q.empty())
{
now=Q.front(); Q.pop(); p[now]=0;
for (i=point2[now];i!=-1;i=next2[i])
if (dist[v2[i]]>dist[now]+c2[i])
{dist[v2[i]]=dist[now]+c2[i];if (p[v2[i]]==0){p[v2[i]]=1;Q.push(v2[i]);}}
}
}
void Astar()
{
priority_queue<datatype>q; cnt=0;
int i,now; double nowg; datatype A; A.g=0.0; A.isk=1; q.push(A);
while ((E>0)&&(!q.empty()))
{
now=q.top().isk; nowg=q.top().g; q.pop();
if (now==N)
{E=E-nowg; if (E>=0) {cnt++;continue;} else break;}
for (i=point[now];i!=-1;i=next[i])
{A.isk=v[i];A.g=nowg+c[i];q.push(A);}
}printf("%d\n",cnt);
}
int main()
{
memset(point,-1,sizeof(point));
memset(point2,-1,sizeof(point2));
memset(next,-1,sizeof(next));
memset(next2,-1,sizeof(next2));
memset(v,0,sizeof(v));
memset(v2,0,sizeof(v2));
memset(c,0,sizeof(c));
memset(c2,0,sizeof(c2));
memset(dist,0x43,sizeof(dist));
memset(p,0,sizeof(p));
scanf("%d %d %lf\n",&N,&M,&E);
int i,x,y; double z;
for (i=1;i<=M;++i)
{
scanf("%d %d %lf\n",&x,&y,&z);
insect(x,y,z);
insect2(y,x,z);
}SPFA();
Astar();
return 0;
}

2016-03-14:改了改之前的手写堆,在codevs上比stl快多了,,,charge呵呵一笑:stl垃圾(内存我懒得改了,,,codevs上A了就行)

#include<queue>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
int duin,N,M,next[200010],point[5010],v[200010],next2[200010],point2[5010],v2[200010];
double c[200010],c2[200010],dist[5010],duif[40000010],E,sum=0;
int cnt=0,cnt2=0,duiu[40000010];
bool vis[5010];
void insect(int x,int y,double z){cnt++;next[cnt]=point[x];point[x]=cnt;v[cnt]=y;c[cnt]=z;}
void insect2(int x,int y,double z){cnt2++;next2[cnt2]=point2[x];point2[x]=cnt2;v2[cnt2]=y;c2[cnt2]=z;}
void swapp(double &x,double &y){double z=x;x=y;y=z;}
void swapp2(int &x,int &y){int z=x;x=y;y=z;}
void SPFA()
{
int i,u; queue<int>q;
for (i=1;i<N;++i) dist[i]=1e150; memset(vis,0,sizeof(vis));
dist[N]=0; vis[N]=1; q.push(N);
while (!q.empty())
{
u=q.front(); q.pop();
for (i=point2[u];i!=0;i=next2[i])
if (dist[v2[i]]>dist[u]+c2[i])
{
dist[v2[i]]=dist[u]+c2[i];
if (vis[v2[i]]==0) {vis[v2[i]]=1;q.push(v2[i]);}
}
}
}
void weihu()
{
duiu[1]=duiu[duin];duif[1]=duif[duin];duin--;
int i=1;
while (i<duin)
{
if (((i*2+1>duin)||(duif[i]<duif[i*2+1]))&&((i*2>duin)||(duif[i]<duif[i*2])))
return;
if (i*2+1<=duin)
if (duif[i*2+1]<duif[i*2])
{
swapp(duif[i*2+1],duif[i]);
swapp2(duiu[i*2+1],duiu[i]); i=i*2+1;
}
else
{
swapp(duif[i*2],duif[i]);
swapp2(duiu[i*2],duiu[i]); i=i*2;
}
else
{
swapp(duif[i*2],duif[i]);
swapp2(duiu[i*2],duiu[i]); i=i*2;
}
}
}
void indui(int u,double f)
{
duin++;duiu[duin]=u;duif[duin]=f;
int i=duin;
while (i>1)
{
if (duif[i]>duif[i/2]) return;
else {swapp(duif[i],duif[i/2]);swapp2(duiu[i],duiu[i/2]); i=i/2;}
}
}
void astar()
{
int u,i,u2; double f,g,f2,g2; cnt=0;
duin=1; duiu[1]=1; duif[1]=dist[1];
while (duin>0)
{
u=duiu[1];f=duif[1];g=f-dist[u]; weihu();
if (u==N){sum+=f; if (sum<=E) {cnt++;continue;} else return;}
for (i=point[u];i!=0;i=next[i])
{
u2=v[i]; g2=g+c[i]; f2=g2+dist[u2];
indui(u2,f2);
}
}
}
int main()
{
scanf("%d %d %lf\n",&N,&M,&E);
int i,x,y;double z;
for (i=1;i<=M;++i)
{
scanf("%d %d %lf\n",&x,&y,&z);
insect(x,y,z); insect2(y,x,z);
}
SPFA();
astar();
printf("%d\n",cnt);
return 0;
}

这样就行啦

codevs 1835 魔法猪学院 A*寻k短路做了一个月卡死在spfa那了/(ㄒoㄒ)/~~的更多相关文章

  1. BZOJ 1975 魔法猪学院(A*求K短路)

    显然每次贪心的走最少消耗的路径即可.那么也就是找出最短路,次短路,,,K短路之后消耗E的能量的最多的路径条数. 也就是裸的A*算法. #include <bits/stdc++.h> us ...

  2. k短路模板(洛谷P2483 [SDOI2010]魔法猪学院)(k短路,最短路,左偏树,priority_queue)

    你谷数据够强了,以前的A*应该差不多死掉了. 所以,小伙伴们快来一起把YL顶上去把!戳这里! 俞鼎力的课件 需要掌握的内容: Dijkstra构建最短路径树. 可持久化堆(使用左偏树,因其有二叉树结构 ...

  3. BZOJ1975 SDOI2010魔法猪学院(启发式搜索+最短路+堆)

    对反图跑最短路求出每个点到终点的最短路径,令其为估价函数大力A*,第k次到达某个点即是找到了到达该点的非严格第k短路,因为估价函数总是不大于实际值.bzoj可能需要手写堆.正解是可持久化可并堆,至今是 ...

  4. BZOJ-1975 魔法猪学院 K短路 (A*+SPFA)

    1975: [Sdoi2010]魔法猪学院 Time Limit: 10 Sec Memory Limit: 64 MB Submit: 1323 Solved: 433 [Submit][Statu ...

  5. Bzoj 1975: [Sdoi2010]魔法猪学院 dijkstra,堆,A*,K短路

    1975: [Sdoi2010]魔法猪学院 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 1357  Solved: 446[Submit][Statu ...

  6. K短路 (A*算法) [Usaco2008 Mar]牛跑步&[Sdoi2010]魔法猪学院

    A*属于搜索的一种,启发式搜索,即:每次搜索时加一个估价函数 这个算法可以用来解决K短路问题,常用的估价函数是:已经走过的距离+期望上最短的距离 通常和Dijkstra一起解决K短路 BZOJ1598 ...

  7. [BZOJ1975][SDOI2010]魔法猪学院(k短路,A*)

    1975: [Sdoi2010]魔法猪学院 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 2748  Solved: 883[Submit][Statu ...

  8. bzoj 1975: [Sdoi2010]魔法猪学院 [k短路]

    1975: [Sdoi2010]魔法猪学院 裸题... 被double坑死了 #include <iostream> #include <cstdio> #include &l ...

  9. bzoj1975: [Sdoi2010]魔法猪学院【k短路&A*算法】

    1975: [Sdoi2010]魔法猪学院 Time Limit: 10 Sec  Memory Limit: 64 MBSubmit: 2446  Solved: 770[Submit][Statu ...

随机推荐

  1. 译:Google的大规模集群管理工具Borg(二)------ Borg架构

    3.Borg 架构 一个Borg的cell由一系列的机器组成,通常在cell运行着一个逻辑的中央控制器叫做Borgmaster,在cell中的每台机器上则运行着一个叫Borglet的代理进程.而Bor ...

  2. UVALive 6449 IQ Test --高斯消元?

    题意:给你一串数字,问这串数字符合f[n] = a*f[n-1],f[n] = a*f[n-1]+b*f[n-2],f[n] = a*f[n-1]+b*f[n-2]+c*f[n-3]这几个方程中的哪个 ...

  3. 给定一个整数实现奇偶bit位互换

    1.分别取出所有奇数bit位和偶数bit位 0x55555555(对应二进制奇数bit位为1,偶数bit位全为0)&num 0xaaaaaaaa(对应二进制即偶数bit位为1,奇数bit位全为 ...

  4. Windows远程桌面连接Ubuntu 14.04

    由于xrdp.gnome和unity之间的兼容性问题,在Ubuntu 14.04版本中仍然无法使用xrdp登陆gnome或unity的远程桌面,现象是登录后只有黑白点为背景,无图标也无法操作.与13. ...

  5. java10-2 toString()方法

    public String toString():返回该对象的字符串表示. Integer类下的一个静态方法: public static String toHexString(int i):把一个整 ...

  6. <转>如何进行code review

    转自: http://pm.readthedocs.org/zh_CN/latest/codereview/howto.html 如何进行code review? code reivew是保障代码质量 ...

  7. ASP.NET 里的 JSON操作

    最近项目中需要用到 JSON操作,google了一下 找到了几个比较好的操作方法.... 一 .使用 mircosoft 提供的 .NET Framework 自带的 json操作方法 1. 使用Ja ...

  8. [Elixir007] on_definition规范函数定义时的各种潜规则

    1.需求 写一个基于memcache的cache模块, 需要在key前面加上特定的前缀, 所以user cache的原始的store函数应该写成 # user.exdef store(user_id, ...

  9. The ServiceClass object does not implement the required method in the following form: OMElement sayHello(OMElement e)

    今天遇到一件诡异的事情,打好的同一个aar包,丢到测试环境tomcat,使用soapui测试,正常反馈结果. 丢到本地tomcat,使用soapui测试,始终报以下错误. <soapenv:En ...

  10. 2016动作短片《全境封锁:特工起源》HD720P.英语中字

    导演: 德文·格雷厄姆主演: Matt Lynch / Sasha Andreev / Amanda Day类型: 动作 / 短片制片国家/地区: 美国语言: 英语上映日期: 2016-01-19片长 ...