본문 바로가기
Programming/BOJ

백준 #1254 팰린드롬 만들기

by 작은별하나 2020. 1. 12.

팰린드롬(Pallindrome)이라는 것은 앞에서 읽어도, 뒤에서 읽어도 같은 숫자나 단어가 되는 것을 말합니다.  예를 들어서 "a nut for a jar of tuna" 은 공백을 제거하면 팰린드롬이 되는 문귀가 됩니다.

 

Pallindrome

 

이번 문제는 주어진 단어에 대해서 적절하게 단어 뒤에 문자를 추가하여 팰린드롬이 되는 단어가 되도록 하는 것입니다.  이 때, 가장 짧은 팰린드로의 길이를 찾아내는 문제죠.  "abba" 와 같은 경우에는 자체로 팰린드롬이므로 4를 출력하면 됩니다.  "banana" 라면 b만 추가하면 "bananab"가 되어 팰린드롬이 되므로 7을 출력합니다.

 

난이도  Silver II에 정답률 40.6%의 평이한 문제입니다.

 

https://www.acmicpc.net/problem/1254 

 

1254번: 팰린드롬 만들기

동호와 규완이는 212호에서 문자열에 대해 공부하고 있다. 규완이는 팰린드롬을 엄청나게 좋아한다. 팰린드롬이란 앞에서부터 읽으나 뒤에서부터 읽으나 같게 읽히는 문자열을 말한다. 동호는 규완이를 위한 깜짝 선물을 준비했다. 동호는 규완이가 적어놓고 간 문자열 S에 0개 이상의 문자를 문자열 뒤에 추가해서 팰린드롬을 만들려고 한다. 동호는 가능하면 가장 짧은 문자열을 만들려고 한다. 동호가 만들 수 있는 가장 짧은 팰린드롬의 길이를 출력하는 프로그램을 작성하

www.acmicpc.net

이 문제는 동적 프로그래밍을 사용하는 문제로 분류가 되어 있습니다.  하지만 동적 프로그래밍이 답일지는 모르겠네요.  가장 좋은 알고리즘은 맨 마지막 글자가 나타날때마다, 연속된 부분 문자열이 팰린드롬인지 검사하는 것입니다.  뭐 어차피 팰린드롬 검사할 때, 맨 마지막 글자와 부분문자열의 맨 처음 글자와 제일 먼저 비교할테니, 크게 상관이 없습니다.

 

제가 작성한 소스 코드입니다.  소스는 참고용으로 봐주세요.

//--------------------------------------------------------------------
//  baekjoon #1254 - Making Pallindrome
//    - by Aubrey Choi
//    - created at 2019-08-05
//--------------------------------------------------------------------
#include <stdio.h>
#include <string.h>

bool check(char str[], int s, int n)
{
  for(s++,n-=2;s<n;) if(str[s++]!=str[n--]) return false;
  return true;
}

int main()
{
  char s[1004];
  gets(s);
  int len=strlen(s), i;
  for(i=0;i<len-1;i++)
  {
    if(s[i]!=s[len-1]) continue;
    if(check(s, i, len)) break;
  }
  printf("%d\n", len+i);
}

  

반응형

'Programming > BOJ' 카테고리의 다른 글

[C/C++] 백준 #1275 커피숍2(세그먼트 트리)  (0) 2020.01.14
#1256 사전(Combination Digit)  (3) 2020.01.13
백준 #1253 좋다  (0) 2020.01.11
백준 #1244 스위치 켜고 끄기  (0) 2020.01.11
백준 #1230 문자열 거리  (0) 2020.01.09

댓글