[BOJ] A와 B 2 12919번 C++

2024. 5. 30. 14:39· Algorithm

 

 

 

문제

수빈이는 A와 B로만 이루어진 영어 단어 존재한다는 사실에 놀랐다. 대표적인 예로 AB (Abdominal의 약자), BAA (양의 울음 소리), AA (용암의 종류), ABBA (스웨덴 팝 그룹)이 있다.

이런 사실에 놀란 수빈이는 간단한 게임을 만들기로 했다. 두 문자열 S와 T가 주어졌을 때, S를 T로 바꾸는 게임이다. 문자열을 바꿀 때는 다음과 같은 두 가지 연산만 가능하다.

  • 문자열의 뒤에 A를 추가한다.
  • 문자열의 뒤에 B를 추가하고 문자열을 뒤집는다.

주어진 조건을 이용해서 S를 T로 만들 수 있는지 없는지 알아내는 프로그램을 작성하시오. 

입력

첫째 줄에 S가 둘째 줄에 T가 주어진다. (1 ≤ S의 길이 ≤ 49, 2 ≤ T의 길이 ≤ 50, S의 길이 < T의 길이)

출력

S를 T로 바꿀 수 있으면 1을 없으면 0을 출력한다.

 

 

접근 방식

 

S로 T를 만들 수 있는 모든 경우의 수를 구하려고 하니 시간초과가 발생했다

따라서 T로 S를 만들 수 있는지 역으로 구했다

1. 문자열의 가장 마지막 문자가 A 라면 해당 문자열 제외하기

2. 문자열의 가장 첫번째 문자가 B 라면 문자열을 뒤집고 해당 문자열 제외하기

 

이렇게 코드를 작성했더니 시간초과가 발생하지 않고 잘 동작하게 되었다!

 

 

코드

 

#include<bits/stdc++.h>
using namespace std;

string S,T;
bool isMake = false;

void sol(string str) {
    if(str.length() == S.length()) {
        if(str == S) isMake = true;
        return;
    }
    if(isMake) return;

    if(str[str.length()-1] == 'A') sol(str.substr(0,str.length()-1));
    if(str[0] == 'B') {
        reverse(str.begin(), str.end());
        sol(str.substr(0,str.length()-1));
    }
    
    

}

int main() {
    ios::sync_with_stdio(false); cin.tie(0);
    cin>>S>>T;

    sol(T);
    if(isMake) cout<<1;
    else cout<<0;
}

'Algorithm' 카테고리의 다른 글

[BOJ] 연산자 끼워넣기 14888번 C++  (1) 2024.06.06
[BOJ] 외판원 순회 2 10971번 C++  (0) 2024.06.06
[BOJ] 링크와 스타트 15661번 C++  (0) 2024.05.29
[BOJ] 도영이가 만든 맛있는 음식 2961번 C++  (1) 2024.05.28
[BOJ] 숫자 야구 2503번 C++  (0) 2024.05.27
'Algorithm' 카테고리의 다른 글
  • [BOJ] 연산자 끼워넣기 14888번 C++
  • [BOJ] 외판원 순회 2 10971번 C++
  • [BOJ] 링크와 스타트 15661번 C++
  • [BOJ] 도영이가 만든 맛있는 음식 2961번 C++
따봉치치
따봉치치
따봉치치
김치치의개발블로그
따봉치치
전체
오늘
어제
  • 분류 전체보기 (359)
    • 면접질문 (4)
    • CS (50)
    • FE (116)
      • Javascipt (16)
      • Typescipt (6)
      • React (16)
      • CSS (5)
      • Nextjs (1)
      • 리뷰 (70)
    • Algorithm (181)
    • ETC (3)
      • Bootcamp (4)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 투 포인터
  • 우선순위 큐
  • 자료구조
  • 데이터베이스
  • 누적합
  • TOPCIT
  • CS
  • C++
  • 그리디
  • 탐욕 알고리즘
  • 모던 리액트 딥다이브
  • 문자열
  • 알고리즘
  • 리액트
  • react
  • 그래프 탐색
  • 모던 자바스크립트 딥다이브
  • 자바스크립트
  • Stack
  • BOJ
  • javascript
  • 스택
  • dp
  • Fe
  • 백준
  • BFS
  • 백트래킹
  • typescript
  • 완전탐색
  • Greedy

최근 댓글

최근 글

hELLO · Designed By 정상우.v4.2.2
따봉치치
[BOJ] A와 B 2 12919번 C++
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.