컴공일기 247
게시글 주소: https://old.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를 선물하세요.
-
영어 사문이 그나마 든든하게 버텨주니까 부담이 좀 덜하네요 믿는 도끼에 발등 찍힐...
-
오른쪽 발목만 피부가 자꾸 쓸리고 까져서 ㅈㄴ 아픔.. 내가 뭐 신발 신고 운동을...
-
존밤되세요
-
슈퍼아이돌이면서 현역 정시로 인서울 대학 간 지헌 누나와 5시간 동안 스터디윗미
-
하아 도파민 과다분비 돼서 잠 못자고 여기까지 와버림
-
아니 어떻게 “다음주” 목요일이 수능이야
-
역대급 캐리판 ㄹㅇ
-
페이커 저 새끼 45세트에 한 것보다 더하라고? 오히려 슌 엘크가 45세트 뒤지게...
-
오늘 실모 보실거임?
-
월즈오면 LCK팀 응원할수밖에없음 ㅋㅋㅋㅋㅋ
-
근데님들 만약애 21월즈때 티원이 담원꺾고 올라갔으면 3
그때 EDG이겼을거같음?
-
4세트 엘크가 성장잘한거 집어던져서 5세트까지 간거고 5세트 빈 느낌없고 온 똥구멍...
-
공통 다 맞을 수 있겠다는 근자감이 드네 ㅋㅋㅋ 제발 25수능수학 공통1틀 미적...
-
ㅅㅅㅅ
-
7번이 진짜 딱 좋을듯
-
닉변완. 3
-
쓰리핏 탐나네 ㅋㅋ
-
ㅈㄴ 무서운데?
-
스킨 후보 10
ㅇㅇ
-
린킨파크 한번만 봐준다 ㅋㅋㅋ
-
아진짜못참겠네 4
헤으응
-
월즈 스킨 예측 6
우스우스: 그라가스 오 너는 최고야: 신짜오 신: 갈리오 or 아리 or 사일러스...
-
나만 그런거 아니지? 걍 지금 씻고 독서실이나 갈까..
-
수능은 티원처럼 7
수능날에 최고점 찍자고
-
캬
-
어 상혁이형이야 0
.
-
건국대 1
건국대 자전 추합 몇번까지 빠질 것 같나요??
-
뭐해? 1
올려
-
실모 풀었는데 둘다 3n점대 나와요...ㅎ ㅠㅠㅠ 수능때 2등급이라도 받고싶은데 걍...
-
아예 버려도 괜찮나요 ?? 이거 버리면 남은 문제는 다 맞아야 하는데 요즘 세포분열...
-
지들 졌다고 시위하는건가 추하네 좀 ㅋㅋㅋ
-
초딩 때부터 게임대회 관심 생겨서 응원했는데 16년 우승보다 지금이 더 기분 좋음...
-
4시드 미드 십캐리 결승 패승패승승
-
23년 3세트 징동한테 무난히 끌려가다가 질뻔한거 토스로 세계선 바꾸고 24년...
-
럭스한적있음??
-
아 개귀엽네ㅋㅋㅋ
-
1사람당 10만덕 댓글 ㄱㄱ혓!
-
대가리 깨러간다 뭐? 국제전 7년 무관? 뭐? 물로켓? 응 월즈리핏 ㅋㅋ
-
초중반 운영은 blg가 훨씬 잘한 것 같은데
-
아 몰라 대상혁 5회 우승 라이브로 봤잖아 한잔해 ㅋㅋㅋ
-
역2롤 t1 faker
-
이래도 까?
-
둘 덕분에 이겼다 ㄹㅇ
-
ㅅㅅㅅㅅㅅ
-
UP
-
시이이이발 대상혁 대상혁 대상혁
-
롤켜야지 0
달려
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자