컴공일기 247
게시글 주소: https://i.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를 선물하세요.
-
어제 발치하고 저녁에는 눈물나게 아팠는데 자고 일어나니까 안 아픔. 그냥 입벌리기 힘든정도?
-
......ㅋㅋㅋ
-
언젠가 독재에 관심가는 분있다고 남겼는데 얼마안되서 학원에서 드물게 그분이랑...
-
“일제, 쌀 수탈 아닌 수출” “임시정부는 단체” 식민지 근대화론 주장하며 독립운동 폄훼 2
“한국사 교과서의 서술은 일제시기 농민의 궁핍을 엉뚱하게도 일제가 쌀을 수탈했기...
-
찬우야 1
꼬두메로 가자이
-
지문의 어려운정도 차이에선 오히려 5-1이 더 어려웠던거 같은데 선지에서 약간...
-
이번 연간패키지에 비연계 문학 N제 꼽껴서 보내줬는데 하프모 형태로 시간관리나...
-
들을사람은 듣고 안들을 사람은 안들으면 되는거아님? 1
물론 본인은 안들을거면 개추 ㅋㅋ
-
친구 만들기..? 말이 좀 이상하긴한데 이런목적인가
-
178/75 mma2년 남자가 여자선수 어디까지 이김? 1
여자는 165/60 가정
-
문학이랑 독서1은 다 들었는데 재종다니소있는데 강의 러닝타임이 너무 길어서.. 그냥...
-
국어 N제 1
지금 김동욱 취클래스 거의 다 했는데 간쓸개나 이감이나 상상이나 이런 것들은 언제...
-
밑줄친 두 표현이 뭐가 다른지 모르겠어용
-
모킹버드 실모 1
저거 사이트에서 추출하는 실모랑 다른거죠?
-
시기가 한정됨 잘못하면 식장 끌려갈 나이임 ㅋㅋ
-
ㄱㅇㅇ
-
퇴근 0
5분 일찍 퇴근하려고 했는데 다른 반 쌤이 퇴근하시면서 채점 파일에 답지오류...
-
하사십 뭐냐 0
ㅅㅂ 70분컷 어캐함;;
-
진정한 킬러삭제에 변별력 있는 수학은 올해 6평인듯 단지 그 방법이 실수유도가 되어버린.
-
Lck도 Lpl도 너무 잘하네 Blg Lng가 진짜 강해보임 웨이보가 우승하면 ㅈㄴ...
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;