-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathEICON.cs
90 lines (81 loc) · 2.51 KB
/
EICON.cs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace TimDuongVer2
{
class EICON
{
static void Main(string[] args)
{
var n = NextInt();
var m = NextInt();
var q = NextInt();
var array = new List<int>[n + 1];
for (int i = 0; i < m; i++)
{
var u = NextInt();
var v = NextInt();
if (array[v] == null)
{
array[v] = new List<int>();
}
array[v].Add(u);
}
StringBuilder result = new StringBuilder();
for (int i = 0; i < q; i++)
{
var u = NextInt();
var v = NextInt();
if (array[u] != null && array[u].Contains(v))
{
result.Append("Y\n");
}
else
{
if (array[u]!=null)
{
var check = 0;
foreach (var each in array[u])
{
if (array[each] != null && array[each].Contains(v))
{
result.Append("Y\n");
check = 1;
break;
}
}
if (check == 0)
{
result.Append("N\n");
}
}
else
{
result.Append("N\n");
}
}
}
Console.Write(result);
}
static int s_index = 0; static List<string> s_tokens;
private static string Next()
{
while (s_tokens == null || s_index == s_tokens.Count)
{
s_tokens = Console.ReadLine().Split(new char[] { ' ' }, StringSplitOptions.RemoveEmptyEntries).ToList();
s_index = 0;
}
return s_tokens[s_index++];
}
private static int NextInt()
{
return Int32.Parse(Next());
}
private static long NextLong()
{
return Int64.Parse(Next());
}
}
}