题解【CF59E Shortest Path】

对于 kkk 对有序的三元组 (x,y,z)(x,y,z)(x,y,z) 为不能走的路线。本题对选择恰当的工具存储三元组有着较高的要求。

首先想到的是 mapset,令 set <int> ban[x][y] 记录形如 x→y→zix \to y \to z_ixyzi 的所有 ziz_izi。进行广度优先搜索,记录一个点 uuu 的前驱 ppp 点的同时遍历后继节点 vvv,若 (u,v,z)(u,v,z)(u,v,z) 合法,即 ban[x][y].find (z) == ban[x][y].end (),同时该路径可以更新,那么加入队列中去并记录下前驱节点(用于路径的输出)。于是得到了以下核心代码:

set <int> ban[MAX][MAX];
void bfs ()
{
   
   
	q.push ({
   
   0,1});
	while (!q.empty ())
	{
   
   
		pair <int,int> x = q.front ();q.pop ();
		int p = x.first,u = x.second;
		if (u == n)
		{
   
   
			printf ("%d\n",dis[p][u]);
			print
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值