컴공일기 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를 선물하세요.
-
수저, 포크를 기본으로 x로 해놓고 매번 변경해야하게 해놓는건 진짜 무슨 생각으로...
-
로고스 인문논술 1
유명하신 쌤들 누구 있음?? 홍대 인문 논술 준비하는데 혹시 아시는 분…
-
물론 작년에만 폭난건지는 모름.. 작년에는 스카이 자연계열 앵간한 공대 입결 다 따네..
-
간호법 악법인건 맞는데 말을 항상 저따구로 하니 여론이 그 모양이지 쯧
-
내리기전 탑승충들 대비해서 전신에 힘 빡 주고(특히 어깨쪽에 집중) 문 끝과 내 몸...
-
킬캠 한번 풀면 그날 하루는 공부에 집중이 안됨 하.... 4점 많이 맞추면 3점...
-
9모 72 인데 평가원 기출이좋을까요 다시개념을해여하나요 아님 스특을풀까요
-
목숨을건KICE와의당일치기한판승부준비하기 일케생각하면뭐가바뀔려나 사실 이거 비슷한거...
-
수학 실모 다시 봐야하나요 아니면 보내줄까요 그냥 풀고 빡쳐서 덮어놓기만 했습니다
-
예쁘고 잘생긴 것도 신기하지만 …원근법인가?
-
6논술하는데 님들은 이거 학교마다 파이널 다 들으시나요? 아니면 꼭 가고싶은 학교...
-
풍경보는거 재밌자너
-
비판갤을 비판
-
레드불 에디션 뭐임?ㅋㅋ
-
( 사회 원로 1500여 명 시국선언 "2000명 증원이라는 대통령의 근거 없는 옹고집이 의료대란,,,얼마나 많은 사람들이 목숨을 잃어야하냐" ) 2
https://www.hani.co.kr/arti/society/society_gen...
-
국영수 높111 과탐 생지 23 이면 올수있다네요 둘다 높은 23
-
신촌맛집 5
디너맛집 추천해주세요!!
-
현실에서도 비내리네.. 우산 없어서 점심먹으러 비 다 쳐맞고 집옴
-
좀 없애라,,,,,
-
고려대학교 수학과 / 기대모의고사 9년차 저자 대학재학시절 수능(평가원) 현장응시...
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자