알고리즘 문제풀이/탐색
백준 1254 [C++]
대엉
2021. 1. 15. 14:00
1254번: 팰린드롬 만들기
동호와 규완이는 212호에서 문자열에 대해 공부하고 있다. 규완이는 팰린드롬을 엄청나게 좋아한다. 팰린드롬이란 앞에서부터 읽으나 뒤에서부터 읽으나 같게 읽히는 문자열을 말한다. 동호는
www.acmicpc.net
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;
}