1. 풀이방법
- 일단 처음 문제를 읽고 든 생각은 제일 길어봤자 문자열의 길이 *2 정도 이겠구나 였습니다.
(뒤에서부터 차례대로 추가하면 되니까)
- 입력은 string으로 받아 편의를 위해 저는 vector<char>에 옮겨 담았습니다.
- 그리고 이제 하나씩 추가를 하고 이게 펠린드롬이 맞는지를 확인하였습니다.
- 반복문만 활용하면 잘 풀 수 있는 문제였습니다.
2. 주의사항
- 없음.
3. 나의코드
#include<iostream>
#include<algorithm>
#include<string>
#include<vector>
using namespace std;
string s;
vector<char> carr;
vector<char> tmpc;
int resultlen;
bool isitpelen() {
for (int i = 0; i < tmpc.size() / 2; i++) {
if (tmpc[i] != tmpc[tmpc.size() - 1 - i]) return false;
}
return true;
}
int main() {
ios_base::sync_with_stdio(false);
cin.tie(0); cout.tie(0);
cin >> s;
for (int i = 0; i < s.length(); i++) carr.push_back(s[i]);
resultlen = s.length();
tmpc = carr;
if (isitpelen()){
cout << resultlen << "\n"; return 0;
}
for (int i = 0; i < s.length(); i++) {
tmpc = carr;
for (int j = i; j >= 0; j--) {
tmpc.push_back(s[j]);
if (isitpelen()) {
cout << resultlen + i + 1 << "\n"; return 0;
}
}
}
return 0;
}
'알고리즘 문제풀이 > 탐색' 카테고리의 다른 글
백준 2776 [C++] (0) | 2021.01.27 |
---|---|
백준 2792 [C++] (0) | 2021.01.26 |
백준 6064 [C++] (0) | 2020.11.30 |
백준 10815 [C++] (0) | 2020.10.25 |
최대공약수 구하기 (재귀,유클리드호제법) (0) | 2020.10.08 |