컴공일기 247
게시글 주소: https://i.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를 선물하세요.
-
명절에도 스카 오지 말고 학교에 가야된다고 생각해요...
-
반공차 공식… 0
볼때마다 아 써야지 하는데 막상 문제 만나면 ..? 이거 뭐 써야했더라 로 인식됨...
-
걍 갈아서 플로우나 숏컷에 넣고 전국서바나 주지 무슨 삼도극 프랙탈 든 실모를 그대로내놓냐 쯧...
-
영어 문제 시간 0
한문제당 몇분 몇초 정도 재고 푸는게 좋을까요
-
하 8
이제 1주일
-
저 놈 왜 안사라지는 거임 왜..? 무지성으로 기함수 싹다 날렸는데…
-
이땐 진짜 하루에 10시간 이상 메이플했었는데 올해 1월이 신창섭이 리부트 죽여서...
-
천만 덕코 드림 4
10M xdk dream
-
공부나해야지 0
카공가자
-
여긴 수험생 갤이니까 공부하려나
-
수특은 가격이라도 싸지
-
ㅇㅇ
-
쉬운 수학 실모 4
추천 해주세요 오르비 기준 말고 진짜 쉬운 실모로용
-
해강 보시나요? 아님 해설지로만 오답하고 끝?
-
취미가 덕코모으기면 데요
-
오늘 할거 0
1.수학 쉬운 실모 하나 풀고 기분 좋아지기 2.국어 3지문만 풀기 3.탐구 실모...
-
어디있었는지 까먹어서...
-
볼륨도 작은데 그냥 대학교에서 배우는 정도로만 해도 충분할 것 같은데 차라리 확률을...
-
송편 맛있네 1
-
근데 왜 앞에 B안달려있지
-
간호학과, 국립대, 인서울도 미달 ㄷㄷ
-
70% 컷이 2.11인데 2등이 2.11이라는 건가요!!??
-
6평치고 지구 시작해서 현재 유자분이랑 oz basic모고 레벨2 진행중입니다. 한...
-
A,B,C의 좌표를 다 구해서 AB와 AC의 같음을 이용해 두점 사이의 거리 공식...
-
이감vs한수 0
국어 교재를 한 지문씩 끊어서 풀면 점수가 잘나오는데, 80분 잡고 이어서 풀면...
-
현대로 보면 솔직히 맞지 않나
-
갠적으로 밀린실모는 파는것보다 기부하는게 더 편한듯 0
하나도 안귀찮음 이번에 삼수하는 친한 동생한테 강사모 몇개 줬다니 좋아해서 내가 더 기분이 좋네
-
정확한 풀이를 모르겟다
-
대성인데 ㅇㅇ
-
EBS좀 보다가 “달러화가 전 세계에 공급되기 위해서는 미국의 국제수지가 계속...
-
수능이 다가온다는 의미겠지 수능날 개같이 지워야지
-
내 텅장 5
올해초엔 분명.... 갑자기 현타오네 재수비용 ㅆㅂ이...
-
ㅎㅎ..
-
13틀 진지하게 못풀었음 뭔가 예상되는 방향에서 계산이 안됨 다른 길이 안 보여서...
-
진짜 어렵네요.. 글을 앞으로쓰는건지 뒤로쓰는건지 뭐라고 쓸지는 알겠는데 무슨...
-
에너지드링크 ON
-
스카 6층인건 5
담배를피지말라는건가...흠
-
10만원짜리 패드로 인강 듣고 있는데 나중에 피뎁 쓸 일이 많아 보여서,,
-
급함
-
갈아만든 ldH 2
-
글 올라오는 속도 왤케 느려
-
다시 영어 기출 분석해보니깐 ㄹㅇ 다른 어떤 지문보다도 재미있네요 보는 시야가...
-
완전 새책입니당 가격은 8천원 입니다 교대역이나 대치동(은마사거리) 직거래 돼요
-
ㅈㄱㄴ
-
좀 대충 어림짐작을 해보고 싶은데 아직도 많아봐야 한 10퍼도 안들어온듯...
-
59일만 하면 되는데 100일때부터 달리지도 못했는데 나쁘지 않은 환경인데 후..
-
6모3 9모3 나왔습니다. 계속 정체된느낌이 들고 해서 실모를 돌려볼까도 생각중인데...
-
9평 느낌 반영 독서 자작 투척 [측정과 국제표준] 3
반영인가? 사실 몰7루?
-
미적 높2 인데. 브릿지랑 비교하면 난이도 어떤 편인지도 말해주세요
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자