컴공일기 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를 선물하세요.
-
나~~중에 "고등학생을 위한 경제 상식" 칼럼 써보겠습니다!! (장기 연재..^^)...
-
진짜 백목이가 제일 맛있음
-
수학 기출 0
공통은 내신하면서 봤는데 대충본거같아도 그냥 킬러만 풀고 4드문 풀어도 될까요
-
순수히 문제만 봤을때… 어느정도였던거같음요 수능에선 이거보다 2등급정도 떨어지려나
-
오우오우 조져버렸고~
-
스카퇴실 1
내일봐용
-
고2 교육청 기준 4등급 정도 나오고 수1 개념 빵꾸나있고 수2는 극대 극소까지...
-
오야스미 2
네루!...
-
안녕하세요 8
안주무시나요 여러분?
-
. . .
-
갑자기 쫄리는데. . . 하. . .
-
이제는 헤어져야 할 시간
-
수능 성적은 국어가 결정한다 올해 좋은 성적 못받더라도 국어등급은 꼭 올려보고싶다
-
국어 공부 추천 1
반수생이고 작수 1 9모 2이고 강민철쌤 현강 듣고있습니다 근데 민철쌤 수업이...
-
질문받음 5
아무거나 ㄱㄱ 시험공부라는걸 좀 하고있다
-
안자는사람 손 15
저요
-
국어꽝 1
여붕이 작수62점 애잔하노ㅋ 역시 강평 올해는?? 두구두구~~~ 몇점?? ~~~
-
11/18 예비군 오라네 병무청 씨발 ㅋㅋ
-
나 청렴한 인물이라 신상털려도 괜찮겠지?
-
이제 정말 30일도 안남은 시점에서 하루하루가 지나가는게 목이 타고 긴장되실겁니다....
-
물리 지리 생명 화학 전 분야에 걸쳐 하루하루가 정말 흥미로웠을듯
-
블라먹었었는데 왜 먹었는지 기억이 안나네요
-
고요한새벽 24
오로지의 탈을 쓴 미하리 등장
-
수학 기출 3
수학 3에서1로 가고싶은데 기출을 풀어야할까요 원래는 1일2실모랑 4드문 하고가려했습니다
-
"여러분께서 갈고 닦은 실력을 보여줄 때가 한 달이 채 남지 않았습니다" 이런...
-
마스크조녜녀 0
눈화장하고 마스크쓰는분있는데 맨얼굴이 궁금하구나
-
. 2
-
goodbay 9
-
구해서 풀만 한가 강k도 퀄 궁금해요
-
좆같네 4
딥피드 어떤글 씨 발
-
최근들어서 9
일주일 넘게 매일 핫식스 6캔씩 마시는 중
-
오르비 기준에선 별로 안 높은듯...
-
큰일났다 4
1시간째 잠 안오는데 수면패턴 맞춰야함 걍 밤새고 수면패턴 정상화가 맞다 이건...
-
옛날기억나네 3
방학때 쳐 놀다가 학교와서 개학첫날 의자에 앉는데 의자에 앉는게 적응이 힘들어서...
-
한양대 제발제발제발
-
표현이 자꾸 지거국 살리기 이래서 그렇지 대학 구조조정의 핵심은 사실 2
수도권 사립 대학임. 연고부터 시작하는 그 라인들. 대다수 입시 커뮤가 찬양해...
-
이 글 재밌다 10
옛날 오르비글인데 흥미로움 https://orbi.kr/00021273069
-
좆!됐!다!
-
선착순 3명 28
이미지 써드림
-
호우 0
환전지연없이 안전한가이트입니다 호우평생주소.com
-
행복하세요? 5
어떤 소원 빌었나요?
-
이제 취침 1
어두운 생각은 잠과 함께 날아갈꺼야
-
달이 예뻐서 한 장 넣었어요 ㅇㅇ..
-
여사친 단 하나도 없음 근데 썸은 몇번 타봤고 연애도 해봄 나도 심심할때 야구장이나...
-
요새 잠도 없고 막하는중
-
생명 스위치를 전원 끄고 켜는것처럼 자신의 의지로 제어 가능하도록 간단하게 바꾸면...
-
강사모고만 풀다보니 뭔가 색이 물든같아서 저자모고도 풀어보려는데 설맞이랑 이해원정도 괜찮을까요?
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자