컴공일기 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를 선물하세요.
-
즐추되세요 3
-
3항부터 53항까지의 홀수항의 갯수,3의배수항의 갯수 이런거 구하기 나만 ㅈㄴ못함?...
-
개인적으로 보자면 시대 서바, 마스퍼티스는 약간 교육청 느낌 더데유데는 평가원 느낌...
-
공하싫 2
그래서 안 하기로 함.
-
ㅈㄱㄴ
-
좀만 늦게 일어나도 독재 결석하고 그래서 같이 기상인증하고 하루 공부한 거 인증하실...
-
저메추 ㄱ 2
-
예비고3이고 고3기준 84 88 92 요정도인거같아요(실모풀면 대부분 88이에요...
-
ㅈㄱㄴ
-
뭐지
-
나도 걍 7
이세계나 가고 싶다
-
뭔일있었나
-
공부하는 날은 확실하게 공부하기 이게맞다
-
돼지될것같은데 2
아
-
강e분 독서 2
걍 인문 철학,과학 기술까지만 하는거 어케 생각하심? 겅제 법 사회는 솔직히 진짜...
-
6평치고 지구 시작해서 현재 유자분이랑 oz basic모고 레벨2 진행중입니다. 한...
-
메인글 개짜증 4
하남자식운영 걍말할것이지 괜히 찝찝하게
-
내년에 이원준T 풀커리 타려고하는데 현강이 주간지 같은거 줘서 더 좋아보이긴 하는데...
-
노력부족이긴하지 실모 풀 때 마다 어떤 문제에서 막히면 너무 자존심 상함. 그러면서...
-
EBS좀 보다가 “달러화가 전 세계에 공급되기 위해서는 미국의 국제수지가 계속...
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자