시간 제한메모리 제한제출정답맞힌 사람정답 비율
2 초 128 MB74959357922449644.688%

문제

바로 어제 최백준 조교가 방 열쇠를 주머니에 넣은 채 깜빡하고 서울로 가 버리는 황당한 상황에 직면한 조교들은, 702호에 새로운 보안 시스템을 설치하기로 하였다. 이 보안 시스템은 열쇠가 아닌 암호로 동작하게 되어 있는 시스템이다.

암호는 서로 다른 L개의 알파벳 소문자들로 구성되며 최소 한 개의 모음(a, e, i, o, u)과 최소 두 개의 자음으로 구성되어 있다고 알려져 있다. 또한 정렬된 문자열을 선호하는 조교들의 성향으로 미루어 보아 암호를 이루는 알파벳이 암호에서 증가하는 순서로 배열되었을 것이라고 추측된다. 즉, abc는 가능성이 있는 암호이지만 bac는 그렇지 않다.

새 보안 시스템에서 조교들이 암호로 사용했을 법한 문자의 종류는 C가지가 있다고 한다. 이 알파벳을 입수한 민식, 영식 형제는 조교들의 방에 침투하기 위해 암호를 추측해 보려고 한다. C개의 문자들이 모두 주어졌을 때, 가능성 있는 암호들을 모두 구하는 프로그램을 작성하시오.

입력

첫째 줄에 두 정수 L, C가 주어진다. (3 ≤ L ≤ C ≤ 15) 다음 줄에는 C개의 문자들이 공백으로 구분되어 주어진다. 주어지는 문자들은 알파벳 소문자이며, 중복되는 것은 없다.

출력

각 줄에 하나씩, 사전식으로 가능성 있는 암호를 모두 출력한다.

예제 입력 1

4 6
a t c i s w

예제 출력 1

acis
acit
aciw
acst
acsw
actw
aist
aisw
aitw
astw
cist
cisw
citw
istw
W3sicHJvYmxlbV9pZCI6IjE3NTkiLCJwcm9ibGVtX2xhbmciOiIwIiwidGl0bGUiOiJcdWM1NTRcdWQ2MzggXHViOWNjXHViNGU0XHVhZTMwIiwiZGVzY3JpcHRpb24iOiI8cD5cdWJjMTRcdWI4NWMgXHVjNWI0XHVjODFjIFx1Y2Q1Y1x1YmMzMVx1YzkwMCBcdWM4NzBcdWFkNTBcdWFjMDAgXHViYzI5IFx1YzVmNFx1YzFlMFx1Yjk3YyBcdWM4ZmNcdWJhMzhcdWIyYzhcdWM1ZDAgXHViMTIzXHVjNzQwIFx1Y2M0NCBcdWFlNWNcdWJlNjFcdWQ1NThcdWFjZTAgXHVjMTFjXHVjNmI4XHViODVjIFx1YWMwMCBcdWJjODRcdWI5YWNcdWIyOTQgXHVkNjY5XHViMmY5XHVkNTVjIFx1YzBjMVx1ZDY2OVx1YzVkMCBcdWM5YzFcdWJhNzRcdWQ1NWMgXHVjODcwXHVhZDUwXHViNGU0XHVjNzQwLCA3MDJcdWQ2MzhcdWM1ZDAgXHVjMGM4XHViODVjXHVjNmI0IFx1YmNmNFx1YzU0OCBcdWMyZGNcdWMyYTRcdWQxNWNcdWM3NDQgXHVjMTI0XHVjZTU4XHVkNTU4XHVhZTMwXHViODVjIFx1ZDU1OFx1YzYwMFx1YjJlNC4gXHVjNzc0IFx1YmNmNFx1YzU0OCBcdWMyZGNcdWMyYTRcdWQxNWNcdWM3NDAgXHVjNWY0XHVjMWUwXHVhYzAwIFx1YzU0NFx1YjJjYyBcdWM1NTRcdWQ2MzhcdWI4NWMgXHViM2Q5XHVjNzkxXHVkNTU4XHVhYzhjIFx1YjQxOFx1YzViNCBcdWM3ODhcdWIyOTQgXHVjMmRjXHVjMmE0XHVkMTVjXHVjNzc0XHViMmU0LjxcL3A+XHJcblxyXG48cD5cdWM1NTRcdWQ2MzhcdWIyOTQgXHVjMTFjXHViODVjIFx1YjJlNFx1Yjk3OCBMXHVhYzFjXHVjNzU4IFx1YzU0Y1x1ZDMwY1x1YmNiMyBcdWMxOGNcdWJiMzhcdWM3OTBcdWI0ZTRcdWI4NWMgXHVhZDZjXHVjMTMxXHViNDE4XHViYTcwIFx1Y2Q1Y1x1YzE4YyBcdWQ1NWMgXHVhYzFjXHVjNzU4IFx1YmFhOFx1Yzc0YyhhLCBlLCBpLCBvLCB1KVx1YWNmYyBcdWNkNWNcdWMxOGMgXHViNDUwIFx1YWMxY1x1Yzc1OCBcdWM3OTBcdWM3NGNcdWM3M2NcdWI4NWMgXHVhZDZjXHVjMTMxXHViNDE4XHVjNWI0IFx1Yzc4OFx1YjJlNFx1YWNlMCBcdWM1NGNcdWI4MjRcdWM4MzggXHVjNzg4XHViMmU0LiBcdWI2MTBcdWQ1NWMgXHVjODE1XHViODJjXHViNDFjIFx1YmIzOFx1Yzc5MFx1YzVmNFx1Yzc0NCBcdWMxMjBcdWQ2MzhcdWQ1NThcdWIyOTQgXHVjODcwXHVhZDUwXHViNGU0XHVjNzU4IFx1YzEzMVx1ZDVhNVx1YzczY1x1Yjg1YyBcdWJiZjhcdWI4ZThcdWM1YjQgXHViY2Y0XHVjNTQ0IFx1YzU1NFx1ZDYzOFx1Yjk3YyBcdWM3NzRcdWI4ZThcdWIyOTQgXHVjNTRjXHVkMzBjXHViY2IzXHVjNzc0IFx1YzU1NFx1ZDYzOFx1YzVkMFx1YzExYyBcdWM5OWRcdWFjMDBcdWQ1NThcdWIyOTQgXHVjMjFjXHVjMTFjXHViODVjIFx1YmMzMFx1YzVmNFx1YjQxOFx1YzVjOFx1Yzc0NCBcdWFjODNcdWM3NzRcdWI3N2NcdWFjZTAgXHVjZDk0XHVjZTIxXHViNDFjXHViMmU0LiBcdWM5ODksIGFiY1x1YjI5NCBcdWFjMDBcdWIyYTVcdWMxMzFcdWM3NzQgXHVjNzg4XHViMjk0IFx1YzU1NFx1ZDYzOFx1Yzc3NFx1YzljMFx1YjljYyBiYWNcdWIyOTQgXHVhZGY4XHViODA3XHVjOWMwIFx1YzU0YVx1YjJlNC48XC9wPlxyXG5cclxuPHA+XHVjMGM4IFx1YmNmNFx1YzU0OCBcdWMyZGNcdWMyYTRcdWQxNWNcdWM1ZDBcdWMxMWMgXHVjODcwXHVhZDUwXHViNGU0XHVjNzc0IFx1YzU1NFx1ZDYzOFx1Yjg1YyBcdWMwYWNcdWM2YTlcdWQ1ODhcdWM3NDQgXHViYzk1XHVkNTVjIFx1YmIzOFx1Yzc5MFx1Yzc1OCBcdWM4ODVcdWI5NThcdWIyOTQgQ1x1YWMwMFx1YzljMFx1YWMwMCBcdWM3ODhcdWIyZTRcdWFjZTAgXHVkNTVjXHViMmU0LiBcdWM3NzQgXHVjNTRjXHVkMzBjXHViY2IzXHVjNzQ0IFx1Yzc4NVx1YzIxOFx1ZDU1YyBcdWJiZmNcdWMyZGQsIFx1YzYwMVx1YzJkZCBcdWQ2MTVcdWM4MWNcdWIyOTQgXHVjODcwXHVhZDUwXHViNGU0XHVjNzU4IFx1YmMyOVx1YzVkMCBcdWNlNjhcdWQyMmNcdWQ1NThcdWFlMzAgXHVjNzA0XHVkNTc0IFx1YzU1NFx1ZDYzOFx1Yjk3YyBcdWNkOTRcdWNlMjFcdWQ1NzQgXHViY2Y0XHViODI0XHVhY2UwIFx1ZDU1Y1x1YjJlNC4gQ1x1YWMxY1x1Yzc1OCBcdWJiMzhcdWM3OTBcdWI0ZTRcdWM3NzQgXHViYWE4XHViNDUwIFx1YzhmY1x1YzViNFx1Yzg0Y1x1Yzc0NCBcdWI1NGMsIFx1YWMwMFx1YjJhNVx1YzEzMSBcdWM3ODhcdWIyOTQgXHVjNTU0XHVkNjM4XHViNGU0XHVjNzQ0IFx1YmFhOFx1YjQ1MCBcdWFkNmNcdWQ1NThcdWIyOTQgXHVkNTA0XHViODVjXHVhZGY4XHViN2E4XHVjNzQ0IFx1Yzc5MVx1YzEzMVx1ZDU1OFx1YzJkY1x1YzYyNC48XC9wPlxyXG4iLCJpbnB1dCI6IjxwPlx1Y2NhYlx1YzlmOCBcdWM5MDRcdWM1ZDAgXHViNDUwIFx1YzgxNVx1YzIxOCBMLCBDXHVhYzAwIFx1YzhmY1x1YzViNFx1YzljNFx1YjJlNC4gKDMgJmxlOyBMICZsZTsgQyZuYnNwOyZsZTsgMTUpIFx1YjJlNFx1Yzc0YyBcdWM5MDRcdWM1ZDBcdWIyOTQgQ1x1YWMxY1x1Yzc1OCBcdWJiMzhcdWM3OTBcdWI0ZTRcdWM3NzQgXHVhY2Y1XHViYzMxXHVjNzNjXHViODVjIFx1YWQ2Y1x1YmQ4NFx1YjQxOFx1YzViNCBcdWM4ZmNcdWM1YjRcdWM5YzRcdWIyZTQuIFx1YzhmY1x1YzViNFx1YzljMFx1YjI5NCBcdWJiMzhcdWM3OTBcdWI0ZTRcdWM3NDAgXHVjNTRjXHVkMzBjXHViY2IzIFx1YzE4Y1x1YmIzOFx1Yzc5MFx1Yzc3NFx1YmE3MCwgXHVjOTExXHViY2Y1XHViNDE4XHViMjk0IFx1YWM4M1x1Yzc0MCBcdWM1YzZcdWIyZTQuPFwvcD5cclxuIiwib3V0cHV0IjoiPHA+XHVhYzAxIFx1YzkwNFx1YzVkMCBcdWQ1NThcdWIwOThcdWM1MjksIFx1YzBhY1x1YzgwNFx1YzJkZFx1YzczY1x1Yjg1YyBcdWFjMDBcdWIyYTVcdWMxMzEgXHVjNzg4XHViMjk0IFx1YzU1NFx1ZDYzOFx1Yjk3YyBcdWJhYThcdWI0NTAgXHVjZDljXHViODI1XHVkNTVjXHViMmU0LjxcL3A+XHJcbiIsImhpbnQiOiIiLCJvcmlnaW5hbCI6IjAiLCJodG1sX3RpdGxlIjoiMCIsInByb2JsZW1fbGFuZ190Y29kZSI6IktvcmVhbiJ9LHsicHJvYmxlbV9pZCI6IjE3NTkiLCJwcm9ibGVtX2xhbmciOiIxIiwidGl0bGUiOiJTZWN1cmluZyB0aGUgQmFybiIsImRlc2NyaXB0aW9uIjoiPHA+RmFybWVyIEpvaG4gaGFzIGluc3RhbGxlZCBhIG5ldyBzZWN1cml0eSBzeXN0ZW0gb24gdGhlIGJhcm4gYW5kIG5vdyBtdXN0IGlzc3VlIGEgdmFsaWQgcGFzc3dvcmQgdG8gdGhlIGNvd3MgaW4gdGhlIGhlcmQuIEEgdmFsaWQgcGFzc3dvcmQgY29uc2lzdHMgb2YgTCAoMyAmbHQ7PSBMICZsdDs9IDE1KSBkaWZmZXJlbnQgbG93ZXItY2FzZSBjaGFyYWN0ZXJzIChmcm9tIHRoZSB0cmFkaXRpb25hbCBsYXRpbiBjaGFyYWN0ZXIgc2V0ICYjMzk7YSYjMzk7Li4uJiMzOTt6JiMzOTspLCBoYXMgYXQgbGVhc3Qgb25lIHZvd2VsICgmIzM5O2EmIzM5OywgJiMzOTtlJiMzOTssICYjMzk7aSYjMzk7LCAmIzM5O28mIzM5Oywgb3IgJiMzOTt1JiMzOTspLCBhdCBsZWFzdCB0d28gY29uc29uYW50cyAobm9uLXZvd2VscyksIGFuZCBoYXMgY2hhcmFjdGVycyB0aGF0IGFwcGVhciBpbiBhbHBoYWJldGljYWwgb3JkZXIgKGkuZS4sICYjMzk7YWJjJiMzOTsgaXMgdmFsaWQ7ICYjMzk7YmFjJiMzOTsgaXMgbm90KS48XC9wPlxyXG5cclxuPHA+R2l2ZW4gYSBkZXNpcmVkIGxlbmd0aCBMIGFsb25nIHdpdGggQyBsb3dlci1jYXNlIGNoYXJhY3RlcnMsIHdyaXRlIGEgcHJvZ3JhbSB0byBwcmludCBhbGwgdGhlIHZhbGlkIHBhc3N3b3JkcyBvZiBsZW5ndGggTCB0aGF0IGNhbiBiZSBmb3JtZWQgZnJvbSB0aG9zZSBsZXR0ZXJzLiBUaGUgcGFzc3dvcmRzIG11c3QgYmUgcHJpbnRlZCBpbiBhbHBoYWJldGljYWwgb3JkZXIsIG9uZSBwZXIgbGluZS48XC9wPlxyXG4iLCJpbnB1dCI6Ijx1bD5cclxuXHQ8bGk+TGluZSAxOiBUd28gc3BhY2Utc2VwYXJhdGVkIGludGVnZXJzLCBMIGFuZCBDPFwvbGk+XHJcblx0PGxpPkxpbmUgMjogQyBzcGFjZS1zZXBhcmF0ZWQgbG93ZXItY2FzZSBjaGFyYWN0ZXJzIHRoYXQgYXJlIHRoZSBzZXQgb2YgY2hhcmFjdGVycyBmcm9tIHdoaWNoIHRvIGJ1aWxkIHRoZSBwYXNzd29yZHM8XC9saT5cclxuPFwvdWw+XHJcbiIsIm91dHB1dCI6Ijx1bD5cclxuXHQ8bGk+TGluZXMgMS4uPzogRWFjaCBvdXRwdXQgbGluZSBjb250YWlucyBhIHdvcmQgb2YgbGVuZ3RoIEwgY2hhcmFjdGVycyAoYW5kIG5vIHNwYWNlcykuIFRoZSBvdXRwdXQgbGluZXMgbXVzdCBhcHBlYXIgaW4gYWxwaGFiZXRpY2FsIG9yZGVyLjxcL2xpPlxyXG48XC91bD5cclxuIiwiaGludCI6IiIsIm9yaWdpbmFsIjoiMSIsImh0bWxfdGl0bGUiOiIwIiwicHJvYmxlbV9sYW5nX3Rjb2RlIjoiRW5nbGlzaCJ9XQ==

출처

Olympiad > USA Computing Olympiad > 2005-2006 Season > USACO November 2005 Contest > Bronze ?번

  • 문제를 만든 사람: author5
  • 잘못된 데이터를 찾은 사람: djm03178
  • 데이터를 추가한 사람: sksdong1