컴공일기 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를 선물하세요.
-
눈치 밥말아먹고 열등감 있고 대체적으로 좀 하는 행동들이 소인배같으면 외모와...
-
과외 드랍할때 3
6평 이후부터 지금까지 수학 과외 했었는데 아마 이번달까지만 할거같음 언제쯤...
-
임정환 현강 다니는데 현강에서도 모고풀고 해설함 뭐 올림픽이런거 복습해야하나 9평...
-
나아님
-
9월 사회문화 해설은 강사가 오개념을 심어줄 수 있다고 봅니다 3
9월 모의평가 사회문화 20번입니다. t 시기 기준 세대별 비율은 다음과 같습니다....
-
어라 방금 일어났는데 시간이
-
일본의 유자와, 미야코지마 미국의 덴버
-
요새 과기대 정시 어느정도임? 친구가 경희시립공대보다 입결높다는데
-
입원하고 이것저것으로 말아먹었었는데요 2학기엔 정말 1등급 중반은...
-
진짜 여신이 따로없다 히히
-
도황
-
ㅅㅅ 3
삼수 사수
-
1) 금수저 2) 몇몇 대학교를 빼고 6년 놀아도 졸업 가능 3) 방학때 야무지게...
-
화학 2
여러분 화학 강대K 모의고사 엄청 어려운거 맞나요…? 저만 그런건가요?? 다른...
-
맨날 어느정도 완성하면 시험 보겠다 하는 얘들 많은데 3
그냥 그 상태로 부딪혀봐야 더 경각심이 생기고 간절함이 생김 맨날 완성 완성...
-
재종이든 독재든 독서실이든 어딜가나 꼭 1명씩은 있나요..적응해야하나
-
특기시험? 폐급으로치는거아닌이상은 지잡대 경제인데 어지간하면가나요?
-
ㅈㄱㄴ
-
고2때 못풀었던거 최근 과외하면서 다시 발견해서 풀어봤더니 올해는 풀리네요 캬캬캬...
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자