You are solving the crossword problem K from IPSC 2014. You solved all the clues except for one: who does Eevee evolve into? You are not very into pokemons, but quick googling helped you find out, that Eevee can evolve into eight different pokemons: Vaporeon, Jolteon, Flareon, Espeon, Umbreon, Leafeon, Glaceon, and Sylveon.
You know the length of the word in the crossword, and you already know some letters. Designers of the crossword made sure that the answer is unambiguous, so you can assume that exactly one pokemon out of the 8 that Eevee evolves into fits the length and the letters given. Your task is to find it.
Input
First line contains an integer n (6 ≤ n ≤ 8) – the length of the string.
Next line contains a string consisting of n characters, each of which is either a lower case english letter (indicating a known letter) or a dot character (indicating an empty cell in the crossword).
Output
Print a name of the pokemon that Eevee can evolve into that matches the pattern in the input. Use lower case letters only to print the name (in particular, do not capitalize the first letter).
Examples
input
7
j......
output
jolteon
input
7
...feon
output
leafeon
input
7
.l.r.o.
output
flareon
Note
Here’s a set of names in a form you can paste into your solution:
[“vaporeon”, “jolteon”, “flareon”, “espeon”, “umbreon”, “leafeon”, “glaceon”, “sylveon”]
{“vaporeon”, “jolteon”, “flareon”, “espeon”, “umbreon”, “leafeon”, “glaceon”, “sylveon”}
Solution:
#include <cstring> #include <vector> #include <list> #include <map> #include <set> #include <deque> #include <stack> #include <bitset> #include <algorithm> #include <functional> #include <numeric> #include <utility> #include <sstream> #include <iostream> #include <iomanip> #include <cstdio> #include <cmath> #include <cstdlib> #include <ctime> #include <memory.h> #include <cassert> using namespace std; string names[8] = {"vaporeon", "jolteon", "flareon", "espeon", "umbreon", "leafeon", "glaceon", "sylveon"}; char foo[42]; int main() { int n; scanf("%d", &n); scanf("%s", foo); for (int i = 0; i < 8; i++) { int u = names[i].length(); if (u == n) { bool ok = true; for (int j = 0; j < n; j++) { if (foo[j] != '.' && foo[j] != names[i][j]) { ok = false; break; } } if (ok) { puts(names[i].c_str()); return 0; } } } puts("not found :("); return 0; }