컴공일기 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를 선물하세요.
-
고쳐주는 댓글보면 짜릿해요
-
오늘의공부 1
국어:비문학비연계3지뮨/문학옛기출3지문/언매한세트 영어:10지문벅벅+단어...
-
백분위 6모 98 9모 91 10모 86 공부 계속 하는데 왜 떨어지는 지를...
-
몇 학년도까지 봐야하는지 감이 안 오네요. 17학년도 정도부터 보면 될까요?
-
퀴즈 1
전자기파에서 전기장과 자기장의 세기의 최댓값을 각각 E, B라고 할 때,...
-
내신을 4 5까지 박은 이상 나에게 다른 선택지는 없다 남은 1년 수능에 미친듯이...
-
원래 어느정도 머리가 좋은데 공부안함:5등급—>2등급 이런경우는 꽤 있겠죠? 근데...
-
보잉님... 3
-
42 43 나오는데 1컷이 44… 멘탈 나가는데요
-
저 궁금한게 생겼는데 잠깐 얘기 가능하신분 있나요? 1
정시수학 관련해서요. . . 삐약이라서 정보얻을곳이 없어요 ㅠ
-
지문 하나 날려도 1이 뜨네
-
어디쯤 갈 수 있을까요? 심리학부로 가고싶은데
-
11월부터는 휴강이고 2주정도 수업 남았는데 그냥 수능 전까지 가지 말까요 수능...
-
통통기준 21 22 29가 많이 어려운데 21,29 꾸역 풀었더니 22는 거의...
-
한능검 .. 20일인데 아직 개념 반도 못들음.. 구냥 포기하까 우우.. 공군가서...
-
ㄹㅇ로 그 악플러 새끼 근성 하나는 개쩔어서 본 받을 만함 88년생이나 되가지고...
-
이번 10모때는 영어 98 나왔는데 오늘 이명학 파이널 푸니까 74점 나오네요.....
-
고1이 지금 국어 평가원 기출 푸는거 의미 있다고 생각하시나요? 2
현재 고1이고 모의고사는 6, 9 둘다 4등급 뜨다가 이번에 강기본 일주일정도 듣고...
-
내 친구가 위에 말한대로 런치고 싶다 햇는데 얼굴에 주먹 내리꽂을뻔 물리랑 미적...
-
실제 지원 저 이후로는 의미 없는 것 같아서 저기서 자름 전글 환장하는 진학사 그래프 참고
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자