컴공일기 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를 선물하세요.
-
호라 모 젠젠 2
재수하면 다이죠부~
-
어우 취한다 5
취기가 올라왔으니 전공공부를 해볼까
-
정상적인 닉으로 돌아옴 24
-
ㅈㄱㄴ
-
그래도 한글 만들어진 조선이 위인가
-
서건창 박병호 쌍으로 말아먹네 ㅋㅋ
-
카페인을 바란다 14
엉망징창
-
죽고싶군. 1
뭐이딴
-
수능 지원한 인원수에 따라 정원을 늘리기 때문인가요?
-
올해는 좀 생길거라는 말이 들리는데 내년엔 어떤가요?
-
2과목을 30에 하자고 해서 말문이 막힘
-
뜬금없는 얘기지만 평소 좋아했던 분이였는데 (롤 닉네임도 욕쟁이할머니) 이렇게...
-
제가 중3~고딩되고 진짜 격차 미친듯이 벌어진듯 의외로 갤탭은 많이 보이더라 화면이 큰게 좋나봐요
-
정장입어야함?
-
상상력 주간지 겨울에도 나와용?
-
ㅈㄱㄴ
-
영어 특) 4
9모 100점 친거로 아직도 수능날 1받겠지라고 망상 오지게 재낌 아 ㅋㅋ 아 리발 꿈.
-
메가패스 사구 뉴런,수분감,시냅스 수1,수2,미적 얼마 나오나요. . .
-
띵학 goat 1
띵학모 풀때는 막 욕하면서 풀리지도 않는거 억지로 푸는데 이거풀다가 다른거 풀면 꽤...
-
수의대 의대 0
수의대가미련에남아요 .. 정신과의사 vs 특수동물수의사 전자도하고싶고후자도하고싶음...
-
강대엉아들 무섭다 ㄷㄷ
-
으아아가가가♡♡♡♡
-
영어가 그렇게 단기간에 오르나요? 9모 3, 10모 2인데 공부 해볼까? 사실 영어...
-
현재 4~50점대 5등급이고 진짜 딱 4만 나와도 됩니다 60점만 넘으면돼요 현재...
-
시민불복종의 폭력사용은 그 종류와 무관하게 정당화 될 수 없으므로...
-
평소 8시간정도 자는데 6시간 쯤 자면 실수가 좀 생기고, 절지만 문제는 풀 수...
-
이번엔 멀로 하지....
-
그 같이 온 ㅇㅇ대학교 어디에 있는 학교임? 하면서 동기들끼리 얘기하는데 (당연히...
-
5회분정도만 풀려는데 뭐 해야될지 고민중
-
두통, 무기력, 졸림
-
엄엄엄노
-
왤케보이냐 아이패드사고 삶의 질이 달라졌는데 ㅋㅋㅋㅋㅋㅋ 12.9인치로 안산거 매일 후회중
-
문제 하나 투척 7
풀어보세요
-
님들이 먼저 외모로 기만했잖음
-
탐구 효율이 더 높다는말 맞긴한거 같아서.. 수학을 맨날 기출 풀고 오답안하고...
-
친구야 봐도 모른척좀 해줘 나 뻘글을 너무 많이 싸놔서 부끄러웡 ㅋㅋㅋ
-
누가 똥글좀 써주라...
-
매일 핸드폰 6
내일은 주말 흐흐흐
-
이투스 모의고사 등급컷 나왔나요?? 안나왔으면 언제쯤 나올까요??
-
전 이제 오르비 끄고 공부하러갈꺼거든요
-
불안하고 손발이 덜덜 떨려요.
-
학종 질문 있음 2
면접 준비 학원가는 게 default임? 대부분 거의 다 감?
-
지금까지 평가원 교육청 화1 생1 쭉 1,2 왓다갓다였는데 10덮 둘다 20점...
-
기만하지 마세요. 10
으
-
6평 86->100 96 2 50 50 9평 83(실채 하나 더맞음)->100...
-
지방의 자랑 "경북대학교 전자공학부" "부산대학교 기계공학과" "경북대학교...
-
문제에서 지괴A가 동일 경도상에서 움직인다 했는데 답지는 북극을 통과한거라고 하는데 오류인가요??
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자