컴공일기 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를 선물하세요.
-
추석 용돈 받음 3
나이스
-
풀고 틀린거 고민 몇분 정도까지 함?
-
제가 수학을 쉽게쉽게만 하는걸까요 머리가 안아퍼요 그렇다고 잘하는건 아니고...
-
공식계정 말고 본닉이 따로 있으싱가
-
07질문받아요 2
심심... 학군지 사는데 고등학교 수시딴다고 먼곳(같은 구 다른 동네)갔다가...
-
인문논술 궁금점 7
쟁점이나 논점이 될만한 부분들 싸그리 모아서 전부 쓰는게 높은 배점을 위한 건지...
-
하는 사람을 현실에서 찾을려면 더 적극적으로 나서야 하는데 마이너 취미 일수록...
-
그냥 아무생각없이 써왔는데 혹시 단위원으로 풀면 안되는 경우도 있나요?
-
하원해버리기
-
저번주말에 같이 먹기로한 친구(아부지가 항공사쪽 일하심) 표 나와서 스위스로 튐
-
바닷가 ㅇㅈ2 4
-
降 1
落
-
제 귀갓길은 으레 밤입니다.하루의 흔적이 뒤꿈치에 길게 늘어져치적치적 걷다 보면발을...
-
우리 학교가 학구열 낮은 지역에 신설 일반고라 소수 극상위권이 포식하는구조라서 지균...
-
이 반 왜 다 여자고딩들이지 갑자기 방 불 끄고 꺄르르 거리는거 좀 당황스럽긴한데...
-
화학 슬럼프? 2
본인 방금 트라이얼2회 풀고옴.결론적으로 47점인데 사실 현재까지 막혀서 틀린적은...
-
제발
-
큐뱅크 같이 들어있는거임?? 큐블라는 보이는데
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자