컴공일기 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를 선물하세요.
-
진짜 행복하다 7
김준티 당첨됨 훈구티 당첨될때보다 더 기쁘네 캬
-
후후
-
아침 8시에 출근... 글고 야근... ㅠㅠ 제한된 시간안에 많은 분량 번역에...
-
자신이 열심히 공부했을때(1주일 평균 순공 60시간) 어떤방법으로 어느 커리를 타야...
-
뉴런 이후에도 기출 강의가 엄청 많던데 딱한가지 종류만 듣는다할때 뭐가 제일...
-
이왜진
-
전국서바 5회 푸는데 15번까지 풀고 16분 남았길래 이거 50각인가 하다가...
-
9모 끝나고 시작해도 괜찮을까? 싶어서요 6모 미적 백분위 85입니다
-
내신 쉬운 대구 농어촌 일반고 다니고 미컴 준비중입니다 국어 학원은 따로 안 다녀요...
-
전역 바로 직전 여행인데...
-
하얀 와이셔츠에 까만 넥타이 사담 없이 빡빡하게 수업하시던 그 모습이 아직도 선명한데 참 아쉽네요
-
둘중 하나만 산다면 어떤거 사는게 나을까요? 그리고 브릿지는 뭔가 종류가 엄청많네요...
-
흐흐흐 사실 허락 맡음
-
머가 있나요?? 성적대는 80~92까지 진동하는데 대부분 계산 좀 복잡하면 실수로...
-
3-4등급 왔다갔다하는데 매일마다 시발점 읽어볼려고 하거든요
-
4점 하프모고 거의 모든 강사컨에 다 잇네 요즘 메타에 참 좋긴 함 저런게
-
실모를 한번도 안 풀어봐서 이거 어려운 거 맞죠? 너무 많이 틀리고 이해 안 가는...
-
수능 최저가 3합7인데 수학이 미적/기하 과목 제한이 있으면 수학을 확통을 보고...
-
저는 민주당 지지자고, 호날두랑 T1을 사랑합니다.
-
고2-3? 고2??
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자