컴공일기 247
게시글 주소: https://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를 선물하세요.
-
비원실 해보신분 0
고난도 지문 (리트) 이거 난이도가 어떤가여 보통 0~1개틀리는데 난이도가 쉬운편인가여?
-
현역으로 들어와서 반수하는 학교 동기 있는데 잇올 관련해서 질문 있으면 나한테...
-
작년리트에선 크게 못느낌요
-
수학 공부법 0
풀다가 도저히 못 풀 거 같다는 문제가 나오면 해설 보고 꼭 했어야 되는 생각 같은...
-
담고싶은거 다 담았다가 만6천원나와서 어거지로 다 먹고 힘들었어
-
올해뭐임
-
특히 추상적인 시들 선지로 출제된거 보면 1. ebs 연계빨로 걍 뚫기 2....
-
우러써
-
모트모트 시켰다 0
한달짜리 두개 시킴
-
국어 1등급으로 만들어준다는 그 책?
-
뉴런 수1 퉆좀 0
수열이 앞에 있는게 1단원이랑 연관성있어서 그런 건 아는데 지수로그 먼저 듣고 수열 듣는건 ㅂㄹ임?
-
같이마시고싶은사람이없음 흠 흠흠
-
참 제가 생각해도 제가 어이가없는게,,,, 독학생이라 아침에 스스로 일어나야해서...
-
[논술]예은논술 제 2차 지원적합 논술 모의고사 모집! 0
마지막 최저의 지표가 될 9월 평가원 모의고사를 앞두고 예은T와 함께 하는 지원적합...
-
3000부 판매신화 기록 지구과학 핵심모음집을 소개합니다. (현재 오르비전자책...
-
운동하고싶은데 0
하 공부 할거 아직 남아있는데
-
오카네 카세구 와타시와 스타
-
주사위에서 홀수나올확률 짝수나올확률이 서로 종속인데 서로 영향을 끼친다는건가요 서로...
-
국어 2409 복합지문 분석 수학 킥오프 함수의 연속 워크북 킥오프 미분계수와...
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;