컴공일기 247
회문(Palindrome).
우영우 기러기 12321과 같이 대칭적인 문자열을 일컫는데,
주어진 문자열에서 범위를 설정하고, 그 범위 내 부분문자열이 회문인지를 검사하는 알고리즘입니다.
우선 완전 탐색을 해야하는 상황이고, 전체 SIZE가 2000 정도로 시간복잡도에 대한 부담감이 없는 상황이네요.
또한 회문 알고리즘의 특성 상 점화 관계를 이용해야 하기 때문에 Dynamic Programming 기법으로 구하는 것이 합당하다고 보여집니다.
아래는 C++로 구현한 코드입니다. 정답이네요.
오랜만에 왔는데, 방금 푼 코드나 올리고 도망가겠습니다. 안녕히 주무십쇼.
#include <iostream>
#define SIZE 2001
using namespace std;
int isPalindrome[SIZE][SIZE];
int arr[SIZE];
int N; //수열의 크기
int M; //질의 개수
int main()
{
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
cin >> N;
// 편의상 index는 1부터 시작
for(int i = 1; i <= N; i++)
{
cin >> arr[i];
}
// 길이 1인 부분 수열은 항상 회문
for(int i = 1; i <= N; i++)
{
isPalindrome[i][i] = 1;
}
// 길이 2인 부분 수열 판단
for(int i = 1; i <= N - 1; i++)
{
if(arr[i] == arr[i + 1])
{
isPalindrome[i][i + 1] = 1;
}
}
// 길이 3 이상인 부분 수열에 대한 회문 판단
for(int length = 3; length <= N; length++) // 부분 수열의 길이
{
for(int i = 1; i <= N - length + 1; i++) // 시작 인덱스
{
int j = i + length - 1; // 종료 인덱스
if(arr[i] == arr[j] && isPalindrome[i + 1][j - 1] == 1)
{
isPalindrome[i][j] = 1;
}
}
}
// 질의 처리
cin >> M;
for(int i = 0; i < M; i++)
{
int S, E;
cin >> S >> E;
cout << isPalindrome[S][E] << "\n";
}
return 0;
}
0 XDK (+0)
유익한 글을 읽었다면 작성자에게 XDK를 선물하세요.
-
요즘 버리는 시간이 많아진거 같아서 저런거라도 해야하나 고민 중 ㅜㅜ
-
평생 자본주의 혜택 오지게 받아놓고 자본주의 시스템 운영자들한테 덕택이랑 투자도...
-
평가원이 수능 난이도 한번씩 조정해주는거 같음 (제발)
-
정시러고 6논술 쓸지말지 고민중 쓰면 독학할건데 그냥 쓰지말고 그 시간에 정시...
-
성적 잘 나오면 국민대 미대 비실기 가고싶긴 하네요 ㅇㅅㅇ
-
자퇴생은 수능성적에 의한 비교내신 산출 이라고만 간단히 써져있는데 아무래도 불리하게...
-
감스트가 보인다면 늦으신겁니다
-
원래 강민철 듣다가 지금 독서가 문제라서 손창빈쌤 들을까 생각중인데요 창반쌤 지금...
-
덕코 다단계로 성공했어요
-
수능 있는 주 월요일 오후라도 가야겠지...?
-
6모 94점(비문학 1개, 문법 1개)이고 반수생입니다. 비문학은 따로 인강듣지...
-
미적 3등급인데 등급 올리기 가능할까요?! 만약 그렇다면 팁이나 공부법...
-
지금처럼 계속 정부랑 강대강 대치 상태가 내년 봄까지도 지속된다면 25학번 의대...
-
일괄 45000원 새상품입니다 쪽지주세여
-
댓글이 안써지는데 왜지? 검1고
-
저도 ebs는 1등급 외에는 왜 하는지 모르겠는 짜피 1등급 아니면 ebs 봐도...
-
전여친한테 커밍아웃한 이후로 올해로만 두번째 커밍아웃이노 그래도 나도 그렇고 그...
-
차렷. 열중 쉬어. 덕코 내놔.
-
연애 하지마셈 11
남들은 지금 파이널 스퍼트하고잇는데 연애? 뭐 짝사랑이나 연애안하기로 결심한 뒤...
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;