컴공일기 247
게시글 주소: https://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를 선물하세요.
-
모두 까기 시대의 막이 올랐다 그런거 할 시간에 문제 풀고 실모보고 애니보고 맛난거 먹는 나
-
걍 작년 수강생중 표준점수 10점 이상 상승비율 수강전 대비 평균 표준점수 상승량...
-
다들 그냥 혼자 하시는건가...?
-
이거 어케풀어요 정답이 ㄷ입니다
-
진짜 냄새남?
-
노베반수생3일차 0
모든 경력을 바다로 열어두고 나 또한 물보라같이 흐느적흐느적 살리라
-
옛날에 LP지문 때려죽어도 이해안됐는데 대학가서 이산수학 하고오니까 너무 쉬워짐
-
남자는 ㅈㅇ이야기 많이하는데 여자는 안하는 이유가 뭐임? 16
반대로 여자는 애인이랑 야스한썰은 푸는데 남자는 그런건 안품
-
곧 1학년 마치고 군대가서 개인공부하려고 어디갈지 고민중인데 해군 수송이 뜨는거같은데
-
논란과는 별개로 모든 국어 강사들 올해 수능 '접수'해야함 5
국어, 한국사만 응시하고 성적 인증 좀 하자 1등급, 백분위 인증하면 절대 까일 일...
-
하지만 돈은 없어서 우러써
-
1. 심찬우가 명지대인건 문제가 전혀 되지않음. but, 국어 성적이 잘나왔다는건...
-
선물받음 0
그림의 떡
-
대충 고2 모고보면 찍맞 빼고 높은 3에서 2초반 정도 나오는데 현재 시발점이랑...
-
수학쌤 도사인가 2
수학숙제 유기하고 물리하다왔더니 “지금 시기에 과학공부하고 그러는 거 아니지?” 이러시네요 ㄷㄷ
-
이번에 학과 보단 좋은 대학을 가기 위해 공부를 시작해보려고 하는데 과목마다 선택이...
-
뭐 그럼 만점들만 강사할 수 있고 공부법에 대해 말할 수 있는거임? 그러면 지금...
-
갤러리 찾아보니까 반수톡방에서 인증한건 있긴한데 이걸론 안되겠죠? 근데 프린트기...
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자