社区讨论

关于 Dinic 模板的某个问题

学术版参与者 2已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@lzc2qpku
此快照首次捕获于
2024/08/02 10:17
2 年前
此快照最后确认于
2024/08/02 11:23
2 年前
查看原帖
已知 Dinic 中分层图的代码可能如下:
CPP
bool bfs()
{
	memset(dist, -1, sizeof(int) * (t + 5)), dist[s] = 0;
	if (s == t) return 1;
	deque<int> qu; qu.push_back(s);
	
	int u;
	while (qu.size())
	{
		u = qu.front(), qu.pop_front();
		cur[u] = head[u];
		for (int i = head[u]; i; i = nxt[i])
			if (w[i] && dist[to[i]] == -1)
			{
				dist[to[i]] = dist[u] + 1, qu.push_back(to[i]);
				if (to[i] == t) return 1;
			}
	}
	return dist[t] != -1;
}
其中 if (to[i] == t) return 1; 这句导致了 TLE,而删掉后能过。
有大佬教一下为啥这会被卡掉吗?

回复

2 条回复,欢迎继续交流。

正在加载回复...