Coding Test/SW Expert Academy
[SWEA] 2007. 패턴 마디의 길이 c++
owls
2022. 11. 15. 09:40
728x90
- 문제
패턴에서 반복되는 부분을 마디라고 부른다. 문자열을 입력 받아 마디의 길이를 출력하는 프로그램을 작성하라.
[제약 사항]
각 문자열의 길이는 30이다. 마디의 최대 길이는 10이다.
[입력]
가장 첫 줄에는 테스트 케이스의 개수 T가 주어지고, 그 아래로 각 테스트 케이스가 주어진다.
각 테스트 케이스의 첫 번째 줄에는 길이가 30인 문자열이 주어진다.
[출력]
출력의 각 줄은 '#t'로 시작하고, 공백을 한 칸 둔 다음 정답을 출력한다.
(t는 테스트 케이스의 번호를 의미하며 1부터 시작한다.)
- 문제 해결
1. substr를 이용해서 마디 검사를 한다.
2. 인덱스로 접근하기 때문에 out of range를 방지하기 위해 인덱스 검사도 추가하였다.
tmp.substr(i, i) : i 부터 i개 까지의 문자열
tmp의 길이가 10, i가 6 이라면 → tmp.substr(6, 6) 으로 out of range 에러가 발생한다.
#include<iostream>
#include <string>
using namespace std;
int main(int argc, char** argv)
{
int test_case;
int T;
cin>>T;
for(test_case = 1; test_case <= T; ++test_case)
{
string str("");
cin >> str;
string pattern(""), tmp("");
for(int i = 2; i < str.size(); i++){
pattern = str.substr(0,i);
if(2 * i <= str.size()){
tmp = str.substr(i, i);
}
if( pattern == tmp){
cout << "#" << test_case << " " << pattern.size() << endl;
break;
}
}
}
return 0;
}
728x90