Loading [MathJax]/jax/output/CommonHTML/jax.js

Problem F. Funny Language

Author:ACM ICPC 2009-2010, NEERC   Time limit:3 sec
Input file:funny.in   Memory limit:256 Mb
Output file:funny.out  

Statement

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 (1im) 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, WiS for any i, and 1im|Si| is maximal, where SiS is the set of words that can be written using letters from Wi.

Input file format

The first line of the input file contains two integer numbers n (1n100) — the number of new words you can add to the dictionary and m (1m1000) — 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.

Output file format

Write to the output file n lines with a new word on a line.

Sample tests

No. Input file (funny.in) Output file (funny.out)
1
3 5
A
ACM
ICPC
CONTEST
NEERC
C
CN
E

0.033s 0.008s 13