컴공일기 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를 선물하세요.
-
아 제발 4
연대가고싶다 아.
-
평가원 전과목 실모 50회분 해마다 만들어줘
-
10모 화1 2
쉬운건 ㅇㅈ 근데 고3표본으로 1컷 50나올 정도라고 ? 올해 06이 잘하는거냐 화1이 ㅈ된거냐?
-
오늘 공부 완료 8
생명 10모 36점 뜬거 보고 멘탈나가서 공부 별로 못함
-
국어 영어 사탐 영역별로 알려주삼 알려주면 수능날 대박터짐
-
1편 보고 와야할둣요.. 공포는 점프스케어 위주고 어디까지가 현실이고 어디까지가...
-
나였으면 그냥 아가리꾹닫았어 무서워서 어케열어
-
[단독]복리 계산·분산투자 못하는 한국인[필수! 금융교육]② 1
편집자주최근까지 금융상품 불완전판매 사태가 계속 벌어지며 사회 이슈가 되고 있다....
-
태블릿 사면서 펜슬도 같이 살까 해서요
-
어디까지 올라가냐
-
1980년대, 빨라도 70년대 고등학생들의 일탈용 도구 중에 본드라는 게 있다. 그...
-
수시를 2장썻기 때문
-
이렇게 불공정한 입시가 유지되는 거 보니. 웟대가리들이 다 문과라 그런가
-
파1보단 어렵나요?
-
논술 복기본도 원본이랑 거의 비슷하게(똑같이) 올리면 안 좋은 일 있으려나..? 9
예를 들자면 위 사진처럼… (원래 복기본은 지움, 괜찮다면 저 파일로 다시 올릴수도..?)
-
9모 96이고 요즘 실모 하방 88 상방 100정도 뜸 1일 2실모 돌리고 있고...
-
제발 ....
-
ㄹㅇ....
-
이 시기가 되면 이 질문을 많이 받습니다. 이 질문은 “저랑 비슷한 수준의 수험생이...
-
1컷 낮3 3 만점 만점으로 텔그 돌렸을 때 경희대 안되는 것도 많고 이대 안되는...
-
주식,선물 하는 입장에서 인터넷 도박, 강원랜드 가는거 9
솔직히 이해가 잘 안가요.판돈도 더 크고 자기 능력여하에 따라 수익을 낼 수도...
-
왼쪽이 보는거랑 오른쪽이 보는게 안맞는거 같은데 사시인가? 아님 책보다가 멀리...
-
저는 이 우주안 보다는 더높은 차원의 존재가 이 우주를 만들었고 관찰하는중이라 생각함
-
목표 1컷이면 1
실모 풀 때 21 22 버려도 되나요… 수열이면 잘 맞추는데 수열 아닌 21 22는...
-
까다로웠네..최댓값 최솟값 접현각 개수 순서쌍 와..어지럽다
-
강게이 ㅅㅂ 2
강k 사문 풀었는데 33점 나옴 끄아악
-
??
-
공부의 중요성?이라는게 사회 전반적으로 떨어져서 그런가... 제가 처음 과외를...
-
수능 목표 1
6평때보다만 잘보자
-
돈 앞에서 인간이 얼마나 추악하고 더러워질 수 있는지 몸소 느껴본 입장에서 자신있게...
-
오리온 2
N제 왤케 쉽징.. 솔텍n2 끝나고 실모랑 병행하려고 오리온이랑 폴라리스 둘다...
-
여친이 네이버 카페하는데 레즈비언인걸 알아냄.... 8
저메추좀
-
ㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋ
-
90분컷 Cex
-
한강 노벨상 그 이틀 뒤 수리논술 재시험 논란 4일 뒤 이제는 초전도체?
-
10모 올 2면 2
사람새끼임?
-
5번까지 신나게 다풀었는데 6번 기하인거보고 아 기하 공부 좀만 더할걸 후회했습니다...
-
https://www.hankyung.com/article/2024101703996
-
진짜로 회전한다치면 모순이 생긴다고 들었는데 전류가 흐르면 자기장이 생기니까 자석은...
-
십구패스 2
2026 19패스 떴네요?!
-
(자작) 확통 30번 문항: 함수의 개수 [간결한 킬러] 0
f: X={1,2,3,4,5}→X, f(n+1)-f(n)≥-1 (n=1~4)
-
탐구를 만점받아서 그런가
-
이약vs연약 2
님들은 어디감?여자라면
-
적중예감, 사만다 s1-3 제외 (이미 푸는 중) 디카프, 퀄 등등 고민 중입니다....
-
해윙 7
-
궁금하네용
-
[속보] 대통령실 "내년 7500명 의대수업, 그렇게 불가능한 것 아냐" 38
[헤럴드경제=서정은 기자] [속보] 대통령실 "내년 7500명 의대수업, 그렇게 불가능한 것 아냐"
-
맨날 비슷한 내용을 주장하는데 세부 소재는 어디서 주워듣고오는지 조금씩 다름...
-
다른거 없음 1과목 중에 텍스트랑 풀이과정 제일 긴데 풀이 공간 제일 작음
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자