컴공일기 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를 선물하세요.
-
국어:10-13회??얘는 기록을 안해서 잘 모름 영어:15?회 수학:100회+하프모...
-
9평 확통 21 28 30 틀렸어요
-
[인문논술] 성균관대 인문사회계 논술, 얼마나 쓰는 게 좋을까? (분량 관련 조언) 16
성균관대 논술의 큰 특징이 있다면, 그것은 바로 답안지가 원고지가 아니라 줄 노트의...
-
사람 수 적으면 보정 좀 해준다는 뜻인가
-
제가 공부를 평생 살면서 길게 해본적이 없습니다! 그런데 이번에 재수하면서 관리형...
-
갑자기 아파져서 오늘내일 공부 못하게 됐는데 이래도 될까요.. 6
학원에 책 가지러 갈 상태도 아니라 ㅠ 이틀 쉬는거 너무 불안한데 어쩌죠
-
없는 건가요 ? 아무리 찾아도 예시답안은 못 찾겠네요 ㅜㅜ
-
‘ 객관적 사실 ‘ 만 전달함 판단은 알아서 ㅎ 단점건물 일주일에 한번꼴공사 -...
-
3개면 충분한가요
-
경제 하고싶었는데 10
정법 <- 이새끼도 컨텐츠 없어서 긁어 모으는디 경제는 진짜 없어보여서 안함
-
이감 어렵당 0
사실 내가 못 하는거지만 문학이 많이 약해졌음...
-
쓰리투원 고지능
-
원함수 왜 이렇게 그려지는 거예요? 도함수에서 원함수니까 x=1 3차인 건 알겠는데...
-
단체소송~
-
우리 학교 문과 실수 애들도 아무도 안하던데 ㅋㅋㅋㅋ
-
두카티
-
시즌1 많이 쉽다는얘기가 많아서 시즌2부터 할지 고민이네요.. 작년수능 96 6월...
-
9평 경제 47 사문 38 더프같은것도 풀면 무보정 기준 사문보다 경제가 더 잘나옴...
-
큐뱅크 같이 들어있는거임?? 큐블라는 보이는데
-
추석이라 내려왔는데, 진짜 삼촌중에 말이 엄!청 많은 삼촌이있는데, 진짜 친척들도...
-
평백이랑 누백 대충 얼마 나와야 됨?
-
오늘 부모님 다 시골 내려가서 집 비어서 나 혼자 심심하고 무서운데 같이 하룻밤...
-
보통 2~1(낮은 1컷)인 분들이 이감 상상 바탕 한수 풀면 어떨땐 90점 초반...
-
질문받아요 32
22, 23 미적 100이고 서울대학교에서 공학(전기정보 or 컴퓨터)과...
-
퀄을 좀 높여라….. 제발 퀄이 낮으니까 시간이 아까움 사문은 무슨 구닥다리 계층...
-
지금읽어도 이해하고 풀려면30분걸리든데.. 나라면 시험장에 못풀고 넘어갈듯
-
사문 생윤 수특 2
풀어야하나요?
-
qna 올리려고 상상홈페이지 들어가려고 하는데 페이지가 안열리는데 나만 이런거임?
-
중견수(CF) 수비는 평균 이상 하는편 실책 1년에 5개정도 1년차 신인 타율 :...
-
개열심히 살거임 수학 황이 되고 싶어
-
어떻게.풀어요..
-
공하싫 2
그래서 안 하기로 함.
-
30살 병역기피자 "유학 보내달라"...법원 "안 된다" 8
[앵커] 병역을 회피하다가 여러 차례 처벌받고선 유학을 위해 해외로 출국하겠다는...
-
공부하기싫다 3
공부하기싫다
-
ㅈㄱㄴ
-
제목그대로 움직도르래 관련 문제 풀면서 얻은 아이디어 및 알고리즘 일반화라고...
-
저메추 ㄱ 2
-
국어 수학 사설 보고 와 이렇게까지 낸다고 이러고 야야 사설 난이도 낮추기 위해...
-
n제 정답률 3
지금 n티켓 푸는데 8문제중에 4~5문제 밖에 못푸는데 계속 해도 될까요?
-
https://orbi.kr/00069182467/%ED%8F%89%EA%B0%80%...
-
야분코삭
-
작년과 비교해서 빡셀까요? 널널할까요? 아님 작년과 같을까요??
-
https://youtu.be/fBTZnwqiH4w?si=XqWxu_SsugeZ4ENn
-
국어 문제 여러개 (어려운거 특히 문학, 승무, 천하의 지도, 9평(이기지 못할...
-
지하철에서 흑인 분 옆에 앉으면 독한 향? 냄새? 때매 너무 힘듦 ㅠㅠ
-
내일부터 공부 인증 안 하면 임기제 부사관 지원함. 20
선착순 10명한테 덕코 줄테니 나 감시 좀.
-
영어 2등급인데 8
워마 2000 단어 세세하게 완벽하게 다 외우는 게 의미가 있나 아니면 그냥 문풀...
-
의대생들 이거 진짜임? 10
진짜 저렇게 올림?
-
그거 분량이 어케 되나요 총 며칠치임
-
그러면 영어 버려도 되잖아
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자