컴공일기 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를 선물하세요.
-
ㄹㅇ....
-
1컷 낮3 3 만점 만점으로 텔그 돌렸을 때 경희대 안되는 것도 많고 이대 안되는...
-
강게이 ㅅㅂ 2
강k 사문 풀었는데 33점 나옴 끄아악
-
언어이해 교수진에서 안보이는데
-
ㅅㅂ 사야되냐 안사도 되겟지?
-
오리온 2
N제 왤케 쉽징.. 솔텍n2 끝나고 실모랑 병행하려고 오리온이랑 폴라리스 둘다...
-
6-6 풀어보고 느낌 전부 쉬운건 아니고 현소나 화학지문은 좀 골때렸지만 그전보다...
-
10모 올 2면 2
사람새끼임?
-
진짜로 회전한다치면 모순이 생긴다고 들었는데 전류가 흐르면 자기장이 생기니까 자석은...
-
십구패스 2
2026 19패스 떴네요?!
-
독서가 약점인데 기출을 더 볼지 수특수완으로 연계 체감을 높일지 고민중인데 수능에서...
-
탐구를 만점받아서 그런가
-
나만 그런거 아니었구나 걍 회차 자체가 빙신이엇다네
-
이약vs연약 2
님들은 어디감?여자라면
-
뭐풀지
-
국어 수학 사설 80점인데 신기하게 수능은 깔끔하게 나와서 작수 국수합...
-
서바 국어 9회 2
파이널 서바 9회 등급컷 아시는 분 계신가요 넘 궁금하네요ㅜㅜ
-
진짜진짜 좋네요… 9모 4떠서 절망했는데(듣기도 틀리긴했지만…) v구문이랑 올인원...
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자