컴공일기 247
게시글 주소: https://iu.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를 선물하세요.
-
고려대 목표라 물지 고집해왔는데 물리가 작수도 4였는데 역학이 도저히 안올라서 걍...
-
순수 실력으로 싸우자.
-
그게 간지니깐... (6모 생윤 4등급)
-
스카이 두원공대 메디컬(한의대) 제가 감히 꿈꿔볼 수 있을까요...
-
국영수가 만약 그대로라 해도 사탐 11이면 우선 목표 하한선은 달성인데... 사탐...
-
문학은 강기분 새기분 다 들었고 독서는 새기분 1권까지 듣다가 유기했음 피램으로...
-
노베이스 계속 열공중이긴한데 남은 기간 영어 사탐만 빡세게해서 최저 맞출라는데 노베...
-
이 사진 보고 난 미 대선도 짜고 치는걸지도 모른다고 생각함 10
이제는 거의 확신의 단계임 월스트리트 재벌들하고 혈통 있는 금융/정치 엘리트 가문...
-
한국사 9모 3이었던내가 수능날 1 받을수있던 비결 10
수능전날 수시황 친구가 1시간 쪽집게 과외해줌 그러고 기출풀고 들어가서 1등급 흐흐
-
K- 아이돌 덕질 왜 하는지 모르겠음
-
다음주에 매개완+oz 추가문제 완강하고 검더텅 풀려고 하는데 검더텅 풀고 유자분...
-
서옥서옥
-
오늘도 화이팅 2
다들 오늘 하루도 화이팅입니다!
-
오르비 과외시장에 몇년째 등록 안되는데 여기서 구해도 됨?? 9
서강대 인문대 다니는 내년에 졸업하는 학원 강사로 이래저래 떠돌며 꾸준히 일한 그런...
-
습습
-
ㅈㄱㄴ
-
권력층 자식이 아이돌 한다고 하면 집안에서 대부분 못하게할까요? 저분들 눈엔 걍 딴따라로 보이려나
-
평생 자본주의 혜택 오지게 받아놓고 자본주의 시스템 운영자들한테 덕택이랑 투자도...
-
너무 맛있네요 해놓고 별점 1 뭐임?? 사장님도 당황하신듯
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;