用广搜实现的spfa

用广搜实现的spfa,如果是用一般的最短路,会发现构图很麻烦,因为它不是路径带权值,而是自身带权值。写起来只要注意,在点出队列的生活将其标记为0,在要压入队列的时候,判断其标记是否为0,为0表示队列中木有这个点,则压入........还有一点,其实这个点即使在队列里面,只要是这个点有比当前的路径短的,就需要更新这个点的最短路,当然,这个点已经在队列里面了,我们就只需要更新它,而不需要把它加入队列......

 

void dj()
{
	queue<node>q;
	for(ss i=0;i<=n;i++)
	for(ss j=0;j<=n;j++)
	dis[i][j]=maxx;
	dis[n][n]=a[n][n];
	memset(vist,0,sizeof(vist));
	vist[n][n]=1;
	node tmp;
	tmp.x=n;
	tmp.y=n;
	q.push(tmp);
	while(!q.empty())
	{
		node tmp1=q.front();
		q.pop();
		vist[tmp1.x][tmp1.y]=0;
		for(ss i=0;i<4;i++)
		{
			ss xx=tmp1.x+t[i][0];
			ss yy=tmp1.y+t[i][1];
			if(xx>=1&&xx<=n&&yy>=1&&yy<=n&&dis[xx][yy]>dis[tmp1.x][tmp1.y]+a[xx][yy])
			{
				dis[xx][yy]=dis[tmp1.x][tmp1.y]+a[xx][yy];
				if(!vist[xx][yy])
				{
					node tmp2;
					tmp2.x=xx;
					tmp2.y=yy;
					q.push(tmp2);
					vist[xx][yy]=1;
				}
			}
		}
	}
}

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值