29442023-02-04 18:31:37horvathabelTom és Jerry 1 (80)cpp17Időlimit túllépés 64/80583ms15852 KiB
#include <bits/stdc++.h>
using namespace std;
vector<pair<int,int>> g[100001];
int tomtav[100001];
vector<bool> mego(100001); 
int t,n,e;
void bfstom(int x){
	bool seen[100001];

	tomtav[x]=0; 
	seen[x]=true; 
	queue<int> q;
	q.push(x);
	while (!q.empty()){
		int v=q.front();
		q.pop();
		
		for (pair<int, int> edge:g[v]){
			if (edge.second==2 && !seen[edge.first]){
				tomtav[edge.first]=tomtav[v]+1;
				q.push(edge.first);
				seen[edge.first]=true;  
			}
		}
	}
}
int bfsj(int x, int e){
	vector<bool> seen(100001); 
	vector<int> jerrytav(100001); 
	vector<int> p(100001); 
	jerrytav[x]=0;
	queue<int> q; 
	q.push(x); 
	p[x]=-1;
	seen[x]=true; 
	while (!q.empty()){
		int v=q.front();
		q.pop();
		
		for (pair<int, int> edge: g[v]){
			if (!seen[edge.first]){
				if ( tomtav[edge.first]==0 || tomtav[edge.first]>jerrytav[v]+1){
					if (edge.first==e) return 1; 
					jerrytav[edge.first]=jerrytav[v]+1;
					q.push(edge.first);
					p[edge.first]=v;
					seen[edge.first]=true; 
			}
				
			}
		} 
	}
	
	
	if (jerrytav[e]==0) return jerrytav[e]; 

	else{
		int z=p[e]; 
		while (z!=x){
			mego[z]=true;
			z=p[z];
		}
	}
	return 1; 
}
int main() {
	
	ios::sync_with_stdio(false);
  	cin.tie(0);
	int n, m,t,jt,e;
	cin>>n>>m>>t>>jt>>e;
	for (int i=0; i<m;i++){
		int x,y,z;
		cin>>x>>y>>z;
		g[x].push_back(make_pair(y,z));	
		g[y].push_back(make_pair(x,z));
	}
	bfstom(t);
	tomtav[t]=-1; 
	
	for (int i=0; i<jt;i++){
		int z; 
		cin>>z;

		
		if (z==e) cout<<"IGEN"<<endl;
		else{
			
			if (bfsj(z,e)==0) cout<<"NEM"<<endl;
			else{
				 cout<<"IGEN"<<endl; 
				for (int i=0; i<n;i++){

				}
			}
		}
	}
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base64/80
1Elfogadva0/06ms8360 KiB
2Elfogadva0/08ms8652 KiB
3Elfogadva4/48ms8788 KiB
4Elfogadva4/48ms9016 KiB
5Elfogadva4/48ms9224 KiB
6Elfogadva4/48ms9228 KiB
7Elfogadva4/48ms9280 KiB
8Elfogadva4/48ms9604 KiB
9Elfogadva4/48ms9732 KiB
10Elfogadva4/48ms9756 KiB
11Elfogadva4/413ms10496 KiB
12Elfogadva4/413ms11040 KiB
13Elfogadva4/417ms11504 KiB
14Elfogadva4/428ms12988 KiB
15Elfogadva4/437ms13988 KiB
16Elfogadva4/443ms14676 KiB
17Elfogadva4/459ms15852 KiB
18Elfogadva4/435ms14244 KiB
19Időlimit túllépés0/4569ms8368 KiB
20Időlimit túllépés0/4560ms8284 KiB
21Időlimit túllépés0/4575ms8316 KiB
22Időlimit túllépés0/4583ms10040 KiB