컴공일기 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를 선물하세요.
-
용어만 안썼을 뿐이지 사실상 전향력 넣은거잖아
-
한 총리 "추석 연휴, 더 위중한 이웃 위해 응급실 양보하는 시민의식 절실" 11
한덕수 국무총리가 12일 의료대란의 고비가 될 수 있는 명절을 앞두고 "많은 병원이...
-
진짜 찢고싶네 이게 하프모의고사가 맞나? 걍 n제잖아....
-
영어 풀 때 멘탈 나가서 잘 못푸는데 오히려 좋아
-
선택들은 다 고만고만한데 공통문제들이 진짜 빡빡한듯. 그래서 상대적으로 선택과목...
-
분명 지난 설, 작년 추석 때 자리 널널했는데 오늘은 40몇석이 꽉 차있네 ;;...
-
사문도 optimal 이 접수한다 딱 나와! 윤카 Out
-
이놈이 공부를 안함. 감시해줄 열품타 구해요.
-
많은 분들의 의견을 더 들어보고 싶어 재업로드 했습니다. 죄송합니다. 정말 정말...
-
현역 질뭍 3
6월부터 전과목 성적이 떡락중이라 7월에 슬럼프와서 한달 놀았는데 떨어지기 전...
-
왜 갑을병정무기경까지 나옴? 옯끼야아아아악
-
adhd라 학창시절때 공부를 못해봐가지고 20중반나이에 겨우 약먹고 9급 합격....
-
88 4문제 틀렸는데 다 3점짜리 시즌 5 3회차 중 가장 망함 국어 3등급 탈출 언제하나
-
배경지식도 그렇지만 사실 더 직접적으로 작용하는 건 그 소재에 대한 친숙도입니다...
-
안녕하세요 저는 일단 06년생 현역이며 체대입시를 준비했었습니다. 2주 전 시즌...
-
안녕하세요 저는 현직 치과의사이고 지난 10년간 대입과 교육에 관심을 가지고...
-
난도는 100분안에풀라고만든게 아닌것같아서 걍 n제느낌으로 풀라하는데 괜찮나요?
-
입원하고 이것저것으로 말아먹었었는데요 2학기엔 정말 1등급 중반은...
-
추석 기념 짤 대방출 17
으히히
-
점심 1
합리적 선택 완
-
분컷 76점.
-
후기좀요
-
아직 나온게 없어서 확정은 아니겠지만 이번 년도랑 비슷하게 가려나요??
-
남들은 땅콩 먹으면 뭐 두드러기난다 뭐다 하는데 전 진짜 두드러기정도가 아니라 몸에...
-
1시간이 뭐냐 1시간이 훈련병 차별 멈춰!
-
화학 3
여러분 화학 강대K 모의고사 엄청 어려운거 맞나요…? 저만 그런건가요?? 다른...
-
실전독해력은 꽝이지만 사후적분석은 굉장히 좋아하는 편이라 이렇게 자주 공부하는데...
-
특기시험? 폐급으로치는거아닌이상은 지잡대 경제인데 어지간하면가나요?
-
모아야 된다 ㅋㅋ 지잡 전문대 고졸 애들 보니까 ㄹㅇ 토나옴 ㅋㅋ 최소 인서울...
-
구라 안치고 너무 쉬운거 아닌가 진작에 수리 논술 좀 준비해서 경기권 말고 다른데...
-
이거 왜나오냐
-
지금LPL상황 0
스카웃 출국금지걸림..
-
뭐사져
-
Ebs 연계를 어느 정도까지 해야함? 예를 들면 해산바가지 하면 스토리를 다 아는데...
-
나도 걍 7
이세계나 가고 싶다
-
진짜 나올 가능성 충분한 게 평가원 이새끼들 2024 수능 때부터 자꾸 미출제요소...
-
바로 들을까요 아님 내일 들을까요?
-
ㅈㄱㄴ
-
과외 드랍할때 3
6평 이후부터 지금까지 수학 과외 했었는데 아마 이번달까지만 할거같음 언제쯤...
-
ㅁㅌㅊ?
-
어떤 해는 모 강사 믿거 이러는데 한 2년 뒤면 그 강사 찬양글 ㅈㄴ 많이 보임
-
연휴라 그런지 식당들이 다 쉰다..
-
물2에선 꿀이지
-
19번 니런버그 실험 실화냐 20번 원형 플라스미드 제한효소 실화냐
-
고2때 못풀었던거 최근 과외하면서 다시 발견해서 풀어봤더니 올해는 풀리네요 캬캬캬...
-
뼈를 깎는 노력(물리)만 하면 180넘음
잘 자
Was it Eliot's toilet I saw?
Bool isPalindrome(const char*);
const char Text[] = “wasiteliotstoiletisaw”;
std::cout << isPalindrome(Text) << std::endl;
문자열 문제는 파이썬으로 풀자