컴공일기 247
게시글 주소: https://iu.orbi.kr/00068916354
회문(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를 선물하세요.
-
9모 88인데 가능한가요? 파이널강의 추천도 좀 부탁
-
또 못봤네 1
-
농어촌 6년 되는데 이 전형을 잘 모르겠기도 하고 이것저것 찾아봐도 자료나 정보가 거의 없어서요..
-
영어 2등급 초중 뜨는데 지문에 모르는 영단어 6개? 정도 있는 것 같음 조정식...
-
두권 합쳐서 60000원입니다!!
-
지구황들 질문좀 4
해설에서 ㄱ판단할때 중심별달라져도 생명가능지대 시작점의 s값과 바깥쪽경계에 도달하는...
-
전 외모는 진짜 딱 첫인상까지만 보는거같아서…
-
인증하면안되는게 1
-
스피드러너 특 4
설마 이계산을? 에이 이 루트면 계산량이 말이 안되는데 다른 길 있겠지 3분간...
-
우상혁 아 그립읍니다
-
ㅈㄱㄴ
-
저거랑 동라인 안 적고 하향 하나 적었는데 위에 다 떨어지면 큰일났네 ㅋㅋ
-
올해 파이널 공부해서 2만들고 고3때 빈칸순삽 정복하고 수능전 파이널 또 보기 어떰?
-
출눈 - 기시감 -포스텝 딱 3권만 했는데 1등급 안정적으로 찍힘 솔직히 사문보다 꿀통이라 생각.
-
오르비언들도 공감하면 개추
-
왜싫어하는거임 ? 슥갈..? 이건또 뭐고
-
민법이 어려운 이유 = 양도 많고, 법리도 난해한데, 심지어 이론과 학설,조문에...
-
오르비 평균이 4
XXL 사이즈던데 유자분하던거 마무리하면 내년에 시작할 다이어트 다 끝낼만한듯...
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자