컴공일기 247
회문(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를 선물하세요.
-
그걸로 친구개수 인싼지 의미 부여하는 병신도잇나여
-
어제 이거 쳐묵하러 갔는데 없더라?????
-
원광대 메디컬 학종은 거의 내신등급을 본다고 들었는데 8
이거 맞는말인가요?
-
할 만함..???
-
재수까지가 마지노선인듯 10
삼수이상부턴 좀 돌이킬수 없는 강을 건너는 느낌 정상궤도를 벗어나는 느낌
-
경지에 오른 것이야
-
아쉽다 참전할걸
-
질문받아요 15
-
히히 똥 발싸 8
히히 발싸 히히
-
존나 어렵네요 진짜 풀거만 풀어도 45점 넘질 못함
-
고3때 내 인스타팔로워 100명보고 우와 많다하면서 은근히 돌리고 나중에 걔가...
-
야밤 질받 27
공부질문도 받습니다
-
세끼를 5
맥도날드에서 해결한 사람..하루정도는 미국인 라이프를 즐겨보았어요
-
⠀
-
아가는 코 하고 잘 시간
-
금테 다셨네
-
밸런스겜한번더? 10
아 재미들렸는뎈ㅋㅋㅋㅋㅋ
-
이거 정지 당하는 건 아니겠지? 실수로 눌러버림...
-
PV=nRT
-
이상형인 동성이랑 연애하기vs그냥 연애 평생 안하기
-
어그로. 대단히 성공적. 물론동평이라한댓글이점메추보다압도적으로많았지만..
-
화학 ㅈ됐는데 5
내신 화학 공부 안해서 진지하게 문제 ㅈ도 안 풀리는데.. 5안으로만 떠다오......
-
버즈도 주고 그랬는데
-
ㅈㄱㄴ
-
파이널2 6-2부터 풀었는데 그 전꺼 사서 풀 필요는 없겟죠?? 컨텐츠는 이원준,...
-
ㄹㅇ어캐하는거임…??
-
심심한데 밸런스겜 11
내가 생각해도 좀 약빤 밸런스겜같긴한데
-
질문받음 6
ㄱㄱ
-
맞팔구함 4
ㅇㅇ
-
진짜..
-
왜 아직도 소드아트온라인 안 나옴?
-
그냥 밤샐까 에펨 너무 하고 싶은데
-
분캠으로 고려대 연세대 뱃지 얻을 수 있었을텐데
-
좆기새끼들 2
ㄹㅇ 개빡치네 자려는데 에에이이이잉 ㅇㅈㄹ
-
옯창 인생 ㅋㅋㅋ 21
외로움 많이 타는 나에겐 최고다
-
앞으로도 잘 부탁드려요
-
하이 하이>< 9평 끝나고 추석 끝나고 좀만 있으면 수능! 우리의 키라키라 윈터...
-
대학은 어디를 생각하고 있니? 아이돌이 밥 먹여주니? 반에서 몇등하니? 이번 9월...
-
자고 일어나면 나아지겠죠 다들 굿밤
-
생각해보면 1
내가 안바뀌면 다시 원래대로 인간관계 같은 것들이 돌아갈 수도 있음 난 이제 나...
-
오늘은 슴슴하네…
-
연시조말구 3줄짜리 시조여
-
남초과여자 여초과남자 19
이신분? 고충을 들어보고 싶음
-
제목 보고 말도 안 된다고 생각하실 수 있겠지만 지구가 시간이 왜이리 부족한지...
-
하루종일 사문수특 ebs인강들으면서 눈떳을때부터 잘때까지 함 전 질려서 3일차부터...
-
오늘 열심히 살게 해줘서 감사합니다 내일 이후는 더 열심히 살거구 내 다짐들을...
-
쉬워진 느낌 안듭니까 ..?. 겉핥기식으로 읽어봤을땐 작냔보단 좀 수월한 것 같아오
-
얼굴 키 목소리 7
1. 얼굴 2. 목소리 3. 키 중요도 순위
-
눈 둘 데를 모르겠더라 여길보고 저길보고 어딜봐도 다 예쁜여자임
-
사탐런치고시픈데 문디컬 문이 엄청 좁으니까 들어가려먼 수학이라도...
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자