컴공일기 247
게시글 주소: https://i.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를 선물하세요.
-
강x 시즌2까지 풀어봤는데 80점대고정임;;최대92 시즌3부턴걍유기하고...
-
걍 하루에 한 챕터씩 나간다고 계획하면 생각보다 안 빡빡한데? 가독성 걱정했는데 걍...
-
지금 수학 2
실모 1개 풀기 > 틀린 유형 고난도 엔제 양치기 > 하프모 2개 이렇게 하고 있는데 ㄱㅊ죠?
-
22번버릴건데 드릴5가 개십어려운관계로 유기 22번보다 약간낮은난이도...
-
수시지원도 다 끝났는데 이제 와서 수시 모집인원을 줄일 수는 없는거고 남은건 정시...
-
막혀가지고 뚫리지가 않네요
-
중국어선도 군인들도 안 보여…“조용해서 더 불안한” 연평도 2
“충분히 국지전이 일어날 것으로 봐. 그리고 그 장소는 아마도 연평도겠지….”...
-
이 방법만 적용하면 지금 바로 영어 점수가 10점은 오릅니다! 2
안녕하세요~ 일등들의 공부법학교 일공학교 입니다^^ 제가 지금까지 수많은...
-
퇴근 1
오늘 존나 보름달이네
-
정치와법(정법) 실모 중 1. 적생모 시즌3 7회 7번에 1번선지 -> 국회가...
-
웅웅
-
생명 질문… 2
ㄴ 보기에서 형질세포가 형성되었다면 생쥐C 의 그래프에서 (가)를 주사했을 때...
-
지구 질문 2
1. (단위시간당 동일한 양의 에너지를 방출하는 면적)/해당 면적 = T^4에 비례...
-
두 학과 동급이란 건 알아요 선호하는 학교학과 골라주시고 학교학과 이름 or 취향...
-
oz는 전시즌 다 샀고 나머진 강k 강k+만 좀 풀어봤어요
-
하루 한끼인데 2
그 한끼가 야식이면 살이 찌는걸까.. ... 나 너무 억울해
-
온순한 사람? 이기적인 사람? 생각이 많은 사람? 화가 많은 사람? 궁굼하네요
-
15분정도 2km씩 매일 뛰는데 상쾌하고조음 수능 끝나고는 확 살빼고싶네요
-
시간 날진 모르겟는데 수능 전에 시간 나면 하나 써볼개요
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자