컴공일기 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를 선물하세요.
-
왜냐면 지에부터 기다림이 24시간으 넘을 때마다 대가리를 존너 쎄게 쳐서 쟈...
-
내가 찬우다
-
모 사이트에 들어가면 만날 수 있다는 이야기가 있다
-
서울대 내신평가 1
세특도 봄?? 2-1까지 내신 2.56인데 세특 의미있음? 개인연구 독서 이런건데...
-
[속보]‘쯔양 협박·공갈’ 구제역·카라큘라·전국진 등 사이버렉카 ‘구속기소’ 2
1000만 유튜버 쯔양(본명 박정원)을 협박해 금품을 갈취하거나 공갈을 방조한 혐의...
-
얼키기 2
얼리 키위새 기상
-
근데 봇치더락은 3
진짜 2기 빼고 할 수 있는건 다하는듯 캬
-
[기대T]올해 연세 모의 해설영상 + Final 안내 6
고려대학교 수학과 / 기대모의고사 9년차 저자 대학재학시절 수능(평가원) 현장응시...
-
꼭 가형 4등급이 나형 1등급을 받는다는 보장은 없지만 2
가4나1통3은 과학입니다. 그럴 만한 실력이 된다는 뜻이다.
-
이거 팔을 땡길때 바깥쪽으로 해야하는건가
-
점메추 4
-
여캐일러 투척. 18
수능 만점 기원 31일차 운루나가 있어서 행복해요
-
혹은 유의미한 상승률은 그 해당강사의 방법론 커리큘럼 강의력을 총체적으로 평가할 수...
-
독서-2점(10번) 문학-3점(25번) 언매-3점(36번) 1컷 83(1등급) 언매...
-
무릎 벗겨진 상처 드레싱한다길래 부드러운 거즈에 연고 듬뿍 묻히고 핀셋으로 살살...
-
수능 국어는 뭔가 수학처럼 개특수(?)같은게 있는듯 4
내용일치 몇 개 빼곤 선지 답보면 결국 지문에서 젤 중요했던게 답임 문학은 주제나...
-
고3 현역분들께 2
힘내세요 입시가 어떻게 끝나는 여러분들 모두 청춘이기에 빛나는 사람입니다!
-
이 글은 도형 문제에서 자주 틀리는 학생들을 위한 글입니다. 내가 도형 문제를 자주...
-
대학생 10명 중 7명 "대학생 때 해외여행은 필수" 11
[서울=뉴시스]윤정민 기자 = 20대 대학생 10명 중 7명은 대학생 때 해외여행이...
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자