컴공일기 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를 선물하세요.
-
다시 갈게요 3
모두 화이팅
-
문학에서 애매하다 느낀 선지로 1차 멘탈 터지고 30분 남기고 독서를 들어가니까 글...
-
갓반고 1학년내신 3.6 2학년 1학기 내신 5.9 여름에 정시로돌리고 2학ㄱ...
-
작수 70점 이후 단어엄청외우고 문제좀풀었더니 이번 6모 79점받았습니다. 이후에...
-
자기가 슬슬 고개도 들수없을거같은 찐허수라면 개.추 눌러볼까?
-
언매황들 질문 1
자음표 모음표 기출에서는 표를 주고 질문을 해왔는데 표 안주고 다음 중 원순모음은...
-
불편한 곳이나 불편한 자세로 자면 조금 자도 불편해서 그런지 잠 자체는 잘 깸...
-
샤인미 모고 1
작년에 풀어보신분 어떠셨나요?
-
마지막 모고로 시간관리 연습 겸 행동 정립하려고 푸는 용도인데 어떤게 더 나아요?
-
잘봤다고 자랑하는 거임 오랜만에 대놓고 기만할거임
-
신체사진 이런거 올라오면 글 바로 썰리지? 작성자 정지당함?
-
최면어플 갖고싶다 15
나한테 써서 밤까지 공부 다 해놓으라고 하는거야
-
어떤 오르비언이 제 수학 풀이 교정해 준 적 있는데 20
나는진짜모든수학문제를개밥찌끄레기처럼풀고있었고내가모르는세계가있다는걸깨달음그사람은아마과외하면뒤지게잘할듯
-
수능 다가오니까 이제야 1티어 작품 내네
-
뭘 잘못했다고 내가 천벌까지 받아야 하니 ㅜㅜ
-
수학 실모 0
수학 얻어갈거 많은 실모 추천 좀 해주세요 해모는 이미 풀었스ㅂ니다
-
진자 ㄹㅇ로 이제 안올테니 기뻐하세요
-
학기 중 꿀알바 과외. 이제는 잡을 수 있습니다. 한창 중간고사 중이거나 끝나는...
-
그립다..
-
육등성이 개조음
-
아쉽다 좀
-
재밌네 ㅋㅋ 1
같잖네
-
그래프 x축에 장난친거 못봐서 13번 날린거 개빡치네 아오
-
답이없다
-
맛팔인사람 따라서 광역팔로우 거는건가 신기하네
-
이거나 반박해보라고요 12
비모순율 : not(A and not A) 비=not 따라서 모순(A and not...
-
그건바로 릿밋핏5행 언어
-
혼밥 9
아싸라서 외로워요
-
기생집vs수분감 0
추천좀
-
작수 독서 0
어려웠? 쉬웠? 언매 문학은 불이었는데 독서는 딱히 불이라곤 못느꼈는데 올해는 작수...
-
우울하네
-
작년엔 쉬어가는 파트라 생각햇는데 올해는 시간 개잡아먹어서 독서에서도 날려읽고......
-
어떻게 생각하시나요
-
쌍사하는데 2
1등급 너무 맞아보고 싶은데 문제집 추천해주셈 참고로 마더텅 빨간색 다 품
-
수완 수학 질문 2
풀이 1은 답이 25가 나오는데 어느 부분이 잘못된 건가요
-
상상 4-2 0
독서 이거맞나..? 아웃소싱 걍 날렸는디 화작은 또 왜이럼 ㅜㅜ
-
f'(x)가 x=3일때 제외하곤 x^2+2x여서 f(x)가...
-
ㅇㅇ 퀄 조지는거 뭐냐 요즘
-
좀 어렵지 않음?
-
비모순율 : not(A and not A) 비=not 따라서 모순(A and not...
-
방법론 행동영역 0
이 둘의 차이가 뭐라고 생각하시나요?
-
내년 수능 보는 사람이 원과목을 고르겠다고 하면 정신이 좀 이상한거임 차라리...
-
근데 왜 하필 공통에서 유일하게 틀린게 독서 어휘문제지…
-
이거 오프랑 똑같나보네요? 제가 알기론 학원에서 밖에 못 구하는걸로 아는데 풀린건가?
-
만족
-
지금까지 한 오답 중에 젤 우울햇음
-
맛있넴 냠냠
-
누가 기절시켰나 나
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자