본문 바로가기

Algorithm

백준 9933번 민균이의 비밀번호

반응형

 

문제

창영이는 민균이의 컴퓨터를 해킹해 텍스트 파일 하나를 자신의 메일로 전송했다. 파일에는 단어가 한 줄에 하나씩 적혀있었고, 이 중 하나는 민균이가 온라인 저지에서 사용하는 비밀번호이다.

파일을 살펴보던 창영이는 모든 단어의 길이가 홀수라는 사실을 알아내었다. 그리고 언젠가 민균이가 이 목록에 대해서 얘기했던 것을 생각해냈다. 민균이의 비밀번호는 목록에 포함되어 있으며, 비밀번호를 뒤집어서 쓴 문자열도 포함되어 있다.

예를 들어, 민균이의 비밀번호가 "tulipan"인 경우에 목록에는 "napilut"도 존재해야 한다. 알 수 없는 이유에 의해 모두 비밀번호로 사용 가능하다고 한다.

민균이의 파일에 적혀있는 단어가 모두 주어졌을 때, 비밀번호의 길이와 가운데 글자를 출력하는 프로그램을 작성하시오.

입력

첫째 줄에 단어의 수 N (2 ≤ N ≤ 100)이 주어진다. 다음 N개 줄에는 파일에 적혀있는 단어가 한 줄에 하나씩 주어진다. 단어는 알파벳 소문자로만 이루어져 있으며, 길이는 2보다 크고 14보다 작은 홀수이다.

출력

첫째 줄에 비밀번호의 길이와 가운데 글자를 출력한다. 항상 답이 유일한 경우만 입력으로 주어진다.

 

 

 

구현은 간단하게 했는데 대칭인 경우 자기자신만으로 비밀번호 일 수도 있기 때문에 비교를 i+1이 아닌 0부터 시작.

 

#include<iostream>
#include<string>

using namespace std;

string str[100];

int main(void)
{
	
	int N;
	bool check = true;
	cin >> N;
	
	
	for(int i = 0; i <N; i++)
	{
		cin >> str[i];
	
	}
	
	for(int i = 0; i < N; i ++)
	{
		string temp = str[i];
	
	
	
	
		for(int j = 0; j < N; j++)
		{
		
		
		
		
			if(temp.length() == str[j].length())
			{
				check = true;
				int mid = temp.length()/2;
					
				for(int k = temp.length()-1; k >= 0; k--)
				{
					if(!(temp[k] == str[j][temp.length()-1-k]))
					{
						
						check = false;
						break;
					}
				}
				
				if(check)
				{
					cout<<temp.length()<<" "<<temp[mid]<<endl;
					return 0;
				}
			}
			else
			{
				
			}
		}
	}
	
}
반응형