컴공일기 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
6평때보다만 잘보자
-
덕갈하고싶다 3
덕코 갈취 하고 싶다라는 뜻
-
내가 처음 메가패스 샀을땐 국어1타가 이원준t였는데 2
영어는 이충권 수학은 현우진(데뷔 1년차)
-
한강 노벨상 그 이틀 뒤 수리논술 재시험 논란 4일 뒤 이제는 초전도체?
-
현역땐 1,2타 말고 안유명한 강사들 듣는거 이해못했는데 2
지금은 유명하고자시고 그냥 자기귀에 잘들어오는 강사 듣는게 짱임
-
5번까지 신나게 다풀었는데 6번 기하인거보고 아 기하 공부 좀만 더할걸 후회했습니다...
-
한국 의사들 "베트남으로 갈래요"…외국인 의사 영어시험 수십 명 응시 3
베트남에 진출하는 우리나라 의사가 크게 늘어날 것으로 전망된다. 최근 한국...
-
안녕하세요..ㅠ 제가 지금 적생모 7회를 학교에 가져와서 풀었는데 답을 놓고와서...
-
https://www.hankyung.com/article/2024101703996
-
작년에 3
그냥 경희대 갈껄... 공대 가서 반수하니 눈물 나네여
-
내가 저번에 작년인가 흉기난동 관해서 개소리 씨부렸던 거 보강함 3
저 당시 경제 불경기에 취업난 때문이라고 했던 거 같은데 추가로 요소를 더해 보자면...
-
지구 수완 2
수특은 했는데 N제를 할까요 수완을 할까요? 솔텍 파트1 다풀고 다음으로 풀 생각
-
궁금하네용
-
국정원 지하에서까지 그런짓을… 에휴
-
외도 들키자 바다에 아내 빠트려 살해…잔혹 남편 징역 28년 확정 3
외도한 사실이 들통나자 아내를 바다에 빠뜨린 뒤 돌을 던져 살해한 30대에게 징역...
-
내가 잘하는 게 아니라 걍 현우진T 문제가 잘 맞는 거 같은데 이러다가 평가원에서...
-
언매 vs 화작 2
둘의 차이점이 시간인가요? 고2 국어 모고 3등급 나오는데 뭘 하는게 좋을까요?...
-
이건 동화 공존 융합 접변이라면 다 가능한거 맞죠?
-
기적인거임?? 기적까진 아닌가..? 참고로)) 전자가 9모 후자가 수능임
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자