CodeForces 164A Variable, or There and Back Again(搜索)

题意

给你n和m,表示有n个状态和m条单向边

快乐路径表示从1开始,2结束的路径,这个路径中间没有1就可以

问你这些状态哪些是快乐路径上的,哪些不是

思路:两次BFS

#include<bits/stdc++.h>
using namespace std;
const int maxn = 1e6+10;
vector<int>e1[maxn];
vector<int>e2[maxn];
int vis1[maxn];
int vis2[maxn];
int a[maxn];
queue<int>q;
int main()
{
    int n,m;
	scanf("%d%d",&n,&m);
	for (int i = 1;i<=n;i++)
		scanf("%d",&a[i]);
	for (int i = 1;i<=m;i++)
	{
		int u,v;
		scanf("%d%d",&u,&v);
		e1[u].push_back(v);
		e2[v].push_back(u);
	}
	for (int i = 1;i<=n;i++)
		if (a[i]==1)
		{
			vis1[i]=1;
			q.push(i);
		}
	while (!q.empty())
	{
		int now = q.front();
		q.pop();
		for (int i = 0;i<e1[now].size();i++)
		{
			int v = e1[now][i];
			if (a[v]==1)
				continue;
			if (vis1[v])
				continue;
			vis1[v]=1;
			q.push(v);
		}
	}
	while (!q.empty())
		q.pop();
	for (int i = 1;i<=n;i++)
	    if (a[i]==2)
		{
			vis2[i]=1;
			q.push(i);
		}
	while (!q.empty())
	{
		int now = q.front();
		q.pop();
		for (int i = 0;i<e2[now].size();i++)
		{
			int v = e2[now][i];
			if (a[v]==1)
				vis2[v]=1;;
			if (vis2[v])
				continue;
			vis2[v]=1;
			q.push(v);
		}
	}
	for (int i = 1;i<=n;i++)
		if (vis1[i]&&vis2[i])
			printf("1\n");
		else
			printf("0\n");
}

Description

Life is not easy for the perfectly common variable named Vasya. Wherever it goes, it is either assigned a value, or simply ignored, or is being used!

Vasya's life goes in states of a program. In each state, Vasya can either be used (for example, to calculate the value of another variable), or be assigned a value, or ignored. Between some states are directed (oriented) transitions.

path is a sequence of states v1, v2, ..., vx, where for any 1 ≤ i < x exists a transition from vi to vi + 1.

Vasya's value in state v is interesting to the world, if exists path p1, p2, ..., pk such, that pi = v for some i(1 ≤ i ≤ k), in state p1Vasya gets assigned a value, in state pk Vasya is used and there is no state pi (except for p1) where Vasya gets assigned a value.

Help Vasya, find the states in which Vasya's value is interesting to the world.

Input

The first line contains two space-separated integers n and m (1 ≤ n, m ≤ 105) — the numbers of states and transitions, correspondingly.

The second line contains space-separated n integers f1, f2, ..., fn (0 ≤ fi ≤ 2), fi described actions performed upon Vasya in state i0represents ignoring, 1 — assigning a value, 2 — using.

Next m lines contain space-separated pairs of integers ai, bi (1 ≤ ai, bi ≤ nai ≠ bi), each pair represents the transition from the state number ai to the state number bi. Between two states can be any number of transitions.

Output

Print n integers r1, r2, ..., rn, separated by spaces or new lines. Number ri should equal 1, if Vasya's value in state i is interesting to the world and otherwise, it should equal 0. The states are numbered from 1 to n in the order, in which they are described in the input.

Sample Input

Input
4 3
1 0 0 2
1 2
2 3
3 4
Output
1
1
1
1
Input
3 1
1 0 2
1 3
Output
1
0
1
Input
3 1
2 0 1
1 3
Output
0
0
0

Hint

In the first sample the program states can be used to make the only path in which the value of Vasya interests the world, 1  2  3  4; it includes all the states, so in all of them Vasya's value is interesting to the world.

The second sample the only path in which Vasya's value is interesting to the world is , — 1  3; state 2 is not included there.

In the third sample we cannot make from the states any path in which the value of Vasya would be interesting to the world, so the value of Vasya is never interesting to the world.



转载于:https://www.cnblogs.com/q934098774/p/5388682.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值