﻿Codeforces Beta Round #76 (Div. 2 Only) B. Friends-Ocrosoft

# Codeforces Beta Round #76 (Div. 2 Only) B. Friends

One day Igor K. stopped programming and took up math. One late autumn evening he was sitting at a table reading a book and thinking about something.

The following statement caught his attention: “Among any six people there are either three pairwise acquainted people or three pairwise unacquainted people”

Igor just couldn’t get why the required minimum is 6 people. “Well, that’s the same for five people, too!” — he kept on repeating in his mind. — “Let’s take, say, Max, Ilya, Vova — here, they all know each other! And now let’s add Dima and Oleg to Vova — none of them is acquainted with each other! Now, that math is just rubbish!”

Igor K. took 5 friends of his and wrote down who of them is friends with whom. Now he wants to check whether it is true for the five people that among them there are either three pairwise acquainted or three pairwise not acquainted people.

Input

The first line contains an integer m (0 ≤ m ≤ 10), which is the number of relations of acquaintances among the five friends of Igor’s.

Each of the following m lines contains two integers ai and bi (1 ≤ ai, bi ≤ 5;aibi), where (ai, bi) is a pair of acquainted people. It is guaranteed that each pair of the acquaintances is described exactly once. The acquaintance relation is symmetrical, i.e. if x is acquainted with y, then y is also acquainted with x.

Output

Print “FAIL“, if among those five people there are no either three pairwise acquainted or three pairwise unacquainted people. Otherwise print “WIN“.

Examples
input
```4
1 3
2 3
1 4
5 3
```

output
```WIN
```

input
```5
1 2
2 3
3 4
4 5
5 1
```

output
`FAIL`

Solution

```#include <set>
#include <map>
#include <list>
#include <cmath>
#include <stack>
#include <queue>
#include <ctime>
#include <string>
#include <cstdio>
#include <vector>
#include <cctype>
#include <climits>
#include <sstream>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm>
#include <functional>
#define strend string::npos
#define ms(a) memset(a,0,sizeof(a))
typedef long long LL;
const LL LINF = LLONG_MAX / 2;
const int INF = INT_MAX / 2;
const int MAXN = 100000 + 10;
const int MOD = 1000000009;
int gcd(int a, int b)
{
if (!b)return a;
return gcd(b, a%b);
}
using namespace std;
//or2..or2..or2..or2..//
int main()
{
int n; cin >> n;
int v[6] = { 0 };
for (int i = 0; i < n; i++)
{
int a, b; cin >> a >> b;
v[a]++, v[b]++;
}
for (int i = 1; i < 6; i++)
if (v[i] != 2) { printf("WIN\n"); return 0; }
printf("FAIL\n");
return 0;
}```