컴공일기 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를 선물하세요.
-
나 어릴 때는 그냥 우리 동네에서만 1타 느낌이었고 학교 내신도 가르치고 그러셨는데...
-
야. 내가 만들었어. https://atom.ac/books/12541/ 구성:...
-
맞다면.. 수능이 코앞인 이 시점에 입시사이트에서 긴 장문을 쓰며 열심히 싸움질하는...
-
만약 내년에 의대에 입학했는데 수업 중지가 계속 교착상태라면 5
바로 공익으로 군대갔다와야겠다
-
수학 97로 생각하니까 상당히 엄스럽네..
-
마이리틀포니 보면서 흥분하는 말박이 부류 빼고는 웬만한건 다 용납함 폴리아모리나...
-
수험생때든 대학생이 되고 나서든 동성은 괜찮은데 이성과 대화하기가 너무 힘들어요..
-
덕코 다단계로 성공했어요
-
93일 3
지구왜안망함
-
내가 ebs만 하고 실모를 딸각딸각풀며 이감 6월 9월 1컷을 맞았는데 어떻게...
-
ㅇㅈ 3
메타 돌때 잘 온건가요?
-
안죽네요?
-
[뉴스데스크] ◀ 앵커 ▶ 논란의 중심에 선 김형석 독립기념관장 외에도, 역사 관련...
-
탐정코난 [916229] to35hour [668545] 아니 예전에 볼땐 탐정코난...
-
ebs 문학은 했고 독서는 대충 했고 언매는 더 대충했다
-
보기에 있는 배경지식이 일종의 엔진 윤활유 역할이라 믿음
-
컴공일기 247 4
회문(Palindrome). 우영우 기러기 12321과 같이 대칭적인 문자열을...
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;