컴공일기 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를 선물하세요.
-
9평 미적 96까지 약 3% 언어와 매체 100, 98 약 2% 수능화 미적 1컷...
-
아 배불러 5
스카가지말까
-
수능때 1컷 노려볼수 있을까요?... 맨날 한문제 정도 못풀고 끝나네요ㅜ
-
ㅈㄱㄴ
-
10모 수학 4
미적 난이도는 모르겠으나 확통 기준 92까지도 못갈 것 같음 왜냐면 내가 88점이거든 시발
-
돈이없어서 시즌2만산다..ㅠ 하나는 설레임샀다 하 찐막은 해모사고 더이상 안사야지 진짜 돈없다
-
겨울방학 목표 2
국어 잘해지기 미적 기출까지 돌리기 이거 두개만 해도 소원이 없을듯
-
서운해서 감 ㅅㄱ
-
듣기도 평가원 중심으로 공부하는게 나음? 아니면 듣기는 쉬워서 아예 차이없나
-
수능이 가까워질수록 공부 더 열심히 할 줄 알았는데 반대로 공부하기가 더 싫어지는...
-
접선의 형용사형인 tangent의 tag-는 만진다는 뜻으로 곡선을 살짝 만진다는...
-
물2 현정훈 없으면 곤란한데 화2로?
-
여르비들만 투표해주세요 ㅠ
-
사문 도표 5
강k나 적중예감 시대인재 같은 사설 모고 풀면 40점대 초반 정도가 나오기는 하는데...
-
시간이 없어서 다 풀어보진 못할 것 같은데 뭐 부터 할까요? 9모 기하 96 댓글로...
-
언미생지인데 상경계열로 교차지원 하면 문과보다 메리트가 큰가요?
-
. 2
-
생윤 개념을 먼저끝내고 사문을 할지 개념 병행을 할지.. 뭐가 더 나을까요 최근...
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자