알고리즘/BOJ

[백준] 12919 A와 B 2

세진짱 2020. 2. 7. 17:39

A와 B의 규칙을 잘 생각해보자

우리는 S->T 가 아닌 뒤집어서 T->S로 문제를 풀어본다!

 

1) 맨 뒤에 A를 붙인다

2) 맨 뒤에 B를 붙이고 뒤집기 => 뒤집고 앞에 B 붙이기

 

 

그럼 문제를 풀기 위해 나올 수 있는 상황 4가지를 생각해보자

 

 

1. A ~ A => 1번경우 가능

2. A ~ B => 불가능

3. B ~ A => 1,2 번 가능

4. B ~ B => 2번가능

 

4가지를 그대로 코딩해주면 시간안에 충분히 나온다!

 

 

 

소스코드

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
string s, t;
 
bool solve(string f) {
    if (f.length() < s.length()) return false;
    if (f.length() == s.length()) return (s == f);
    bool ret = false;
    char s = f[0], e = f.back();
    int len = f.length();
    if (s == 'A') {
        if (e == 'A') ret |= solve(f.substr(0, len - 1));
        else return false;
    }
    else {
        if (e == 'A') ret |= solve(f.substr(0, len - 1));
        reverse(f.begin(), f.end());
        f.pop_back();
        ret |= solve(f);
    }
    return ret;
}
int main() {
    cin >> s >> t;
    printf("%d\n", solve(t));
}