컴공일기 247
게시글 주소: https://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
오열 그자체긴 함. 문학 감상 그딴 거 없음. (아예 없다는 소리는 아니고 뜻...
-
내 실질 점수는 92점인데 이건 사실 풀수있었던거였으니까 난 96점 임 암튼그럼...
-
빡모 좋다해서 풀어봤는데 계속 80초 뜹니다 어느정도 난이도에요? (시즌1)
-
아니 이거 인물관계 왤케 복잡하냐거 아오 아오
-
오뿌이들아 뭐해 0
똥글은 안 올라오는데 조회수 왜케 잘나옴 ㄷㄷ
-
개인적으로 엄청 잘 들었던 입장으로써 오개념이 사실이라면 하셨던 말대로라면 은퇴를...
-
민주당 김영환 "주가하락 확신 있으면 인버스 잡으면 되지 않나" 0
이 미친놈 주둥아리를 그낭
-
다른게 ㅈㄴ어려워서 Tlqkf
-
수학 공부 질문 4
질문이 좀 많은데 일부라도 대답해주실수 잇는분 남겨주시면 감사하겟습니다.. 작수...
-
화1 서바 1
요즘 나만 쉽다고 느끼는거 아니지…? 풀고 왜 시간이 남냐 서바답지 않게
-
앉자마자 처음 두시간은 오르비를 하고 그다음 마음의 가다듬기 위한 한시간을 쓰고...
-
쉬울땐 1개인거고? 92점 안정적으로 받으려면 발상적인거 매달리면 안되겠네
-
님들 그래서 수능 3주전부터 국어 실모 몇개풀어야됨 1
메인에 저렇게 논란이있으니 궁금하군
-
일주일에 얼마나 대체가능?
-
아니 과외생 10
성장속도가 개빠르네.. 12번같은거 막히던애가 20일만에 22번 품
-
외대 자퇴 1
차선책으로 온 사범 대학인데 적응을 몇 년째 못하고 있습니다. 이대로 허송세월...
-
가능할까요..!! 가능세계 물어서 죄송하무니다?
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자