Author: | ACM ICPC 2009-2010, NEERC | Time limit: | 3 sec | |
Input file: | funny.in | Memory limit: | 256 Mb | |
Output file: | funny.out |
There is a well know game with words. Given a word you have to write as many other words as possible using the letters from the given word. If the letter repeats multiple times in the original word, you can use it up to as many times in the new words. The order of letters in the original word does not matter. For example, given the word CONTEST you can write NOTE, NET, ON, TEST, SET, etc.
Now you are in charge of writing a new dictionary. Your task is to sneak n new words into it. You know in advance m words Wi (1 ≤ i ≤ m) that you will have to play a game with and you need to figure out which new n words to add to the dictionary to maximize the total number of words you can write out of these m words.
More formally, find such a set of nonempty words S where |S| = n, Wi ∉ S for any i, and ∑1 ≤ i ≤ m|Si| is maximal, where Si ⊂ S is the set of words that can be written using letters from Wi.
The first line of the input file contains two integer numbers n (1 ≤ n ≤ 100) — the number of new words you can add to the dictionary and m (1 ≤ m ≤ 1 000) — the number of words you will play the game with. The following m lines contain original words. Each word consists of at most 100 uppercase letters from A to Z.
Write to the output file n lines with a new word on a line.
No. | Input file (funny.in ) |
Output file (funny.out ) |
---|---|---|
1 |
|
|