컴공일기 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를 선물하세요.
-
자고 일어나면 나아지겠죠 다들 굿밤
-
생각해보면 1
내가 안바뀌면 다시 원래대로 인간관계 같은 것들이 돌아갈 수도 있음 난 이제 나...
-
오늘은 슴슴하네…
-
연시조말구 3줄짜리 시조여
-
남초과여자 여초과남자 19
이신분? 고충을 들어보고 싶음
-
제목 보고 말도 안 된다고 생각하실 수 있겠지만 지구가 시간이 왜이리 부족한지...
-
하루종일 사문수특 ebs인강들으면서 눈떳을때부터 잘때까지 함 전 질려서 3일차부터...
-
오늘 열심히 살게 해줘서 감사합니다 내일 이후는 더 열심히 살거구 내 다짐들을...
-
쉬워진 느낌 안듭니까 ..?. 겉핥기식으로 읽어봤을땐 작냔보단 좀 수월한 것 같아오
-
얼굴 키 목소리 7
1. 얼굴 2. 목소리 3. 키 중요도 순위
-
눈 둘 데를 모르겠더라 여길보고 저길보고 어딜봐도 다 예쁜여자임
-
사탐런치고시픈데 문디컬 문이 엄청 좁으니까 들어가려먼 수학이라도...
-
에타펌
-
양평이투스247 0
양평이투스247 예비고3 윈터스쿨 신청할려고 하는데 어떤가요?
-
별생각 안드는데 나보다 어깨넓은 여자는… 빨리 그 자리를 벗어나고싶음
-
지문풀때 모르는단어가나오면 어떻게 하나요? 빈출단어장을 마니외워봐도 지엽적인단어가...
-
어떻게 문제집 이름이 엄마혀
-
맛있는 중국음식 먹게 해주셔서 감사합니다. 맛있는 서머스비 마시게 해주셔서...
-
위트충이지만 유포터블이 진짜 대단하다고 느꼈음 수능 끝나면 꼭 보셈
-
아직도 마더텅만큼 뜨거운 녀석은 없었네요
-
국어실모 2
대체 므ㅓ가 좋은지 멀겠으무ㅜ ㅜ
-
기부하려는데 1
고향사랑기부제에 기부할까? 물론 강남 서울런같은 곳에 기부하는 방법은 없으려나
-
피의 공부머신 어쩌고저쩌고
-
수험생 꿀팁 15
난 생각보다 똑똑하다 라는 말을 스스로에게 반복해서 최면 걸면 문제 ㄹㅇ 잘 풀리는...
-
덕미새 등장 11
계속 있기
-
여자들은 별론가요?? 약간 여러 여자 찔러보고 이쁜 여자에게 금방 빠지는 타입요....
-
현강가면 격하게 느낌 예쁜애는 10퍼는되는데 잘생긴애는 0퍼임
-
뭔가.. 답인거 같으면 고르고 속으로 ㅅㅂ 이게 아니면 뭔데 ㅋㅋ 이 마인드로 찍고...
-
고2 정시파이터인데 이번에 자퇴를 해서,, 지금 오르새 선생님 개념에센스 듣는...
-
문제풀다가 1교시에 지문이상하게 읽었다고 생각이들어도 내가 푼게 맞다라는 마인드가...
-
갑자기 문학 확 잘해져서 강사뽕 오지게차네
-
. 2
-
성균관대 교과 학교장추천으로 사회복지학과 썼는데요 20명 모집 152명 지원했습니다...
-
전 오늘 시켰는데 언제쯤 올까요ㅋㅋㅋㅋ
-
어떻게든 틀리라고 고사지내는거같음
-
검치고고혓
-
썸타는중 0
썸 (41의 음악에 맞춰 박자를) 타는 중
-
문과 과탐 0
문과에서 수시로 상위권 대학을 노리는데 내신에서 과탐비중이 얼마정도를 차지하나요?...
-
욕심을 부리면 망하기 쉬움 특히 재수생. 목표가 높으면 시험장에서 욕심을 부리기...
-
그래도 남자보단 여자가 좋은 것 같음
-
수능날 이 세 능력 중에 뭐가 제일 좋아보이나요? 97
존야의 모래시계는 컨닝불가, 본인 시험지만 볼 수 있다고 제한 걸어야 밸런스 맞을듯요
-
다들 5
가치있는 삶은 어떤 삶이라 생각하세요?
-
26살에 대학교 입학하면 취업이나 할 수 있어요..? 6
SKY는 못 갈거 같고 SSH 간다고 치면 취업은 가능하긴함? 화작확통생윤사문이라...
-
아무질문이나 다받아요 ㄱㄱ
-
응 D-424야
-
지구 무서운점 10
이상하리만치 순조롭게 시작함 15번까지 물 흐르듯 풂. 개념문제 하나 헷갈리긴...
-
고등학교랑 대학동기들 공군이랑 고민하다가 갔다왔는데 ㄹㅇ ㄱㅊ은거같음
-
일단 본인은 진짜 열심히 싸울 자신 있음ㅇㅇ
-
잘한다 Or 못하진 않다 Or 못한다 어떤 느낌임??
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자