백준 1787 - 문자열의 주기 예측
위 포스트는 백준 1787 - 문자열의 주기 예측 의 해설입니다. 결국 부분 문자열에서 가장 짧으면서 일치하는 Prefix와 Suffix를 찾으면 된다. (해당 길이를 전체…
2025/03/05
Jinsoolve.
Categories
Tags
3월 안에는 꼭...
About
위 포스트는 백준 6569 - 몬드리안의 꿈에 대한 해설입니다.
... | ... | ... | ... | ... | ... | ... | ... |
---|---|---|---|---|---|---|---|
채워짐 | 채워짐 | 채워짐 | 채워짐 | 채워짐 | 채워짐 | 채워짐 | 채워짐 |
채워짐 | 채워짐 | 채워짐 | 채워짐 | w-1 | ... | ... | ... |
... | 2 | 1 | 0 | (h,w) |
위와 같이 큰 직사각형이 존재한다고 하자.
dp[h][w][bit] := bit상태일 때, (h,w)부터 끝까지 큰 직사각형을 2x1 직사각형으로 채우는 경우의 수
라 하자. (이때 (0,0) ~ (h-1,w-1) 영역은 모두 채워져 있음을 가정한다.)
여기서 bit는 w개의 bit로 이루어져 있는데, 이는 (w-1) (w-2) ... (2) (1) (0) 을 의미한다.
각 비트는 채워진 여부를 의미한다. 0이면 비어있고 1이면 채워져 있다.
이때 다음과 같이 풀면 된다.
cpp1#include <bits/stdc++.h> 2 3#define endl "\n" 4#define all(v) (v).begin(), (v).end() 5#define all1(v) (v).begin()+1, (v).end() 6#define For(i, a, b) for(int i=(a); i<(b); i++) 7#define FOR(i, a, b) for(int i=(a); i<=(b); i++) 8#define Bor(i, a, b) for(int i=(a)-1; i>=(b); i--) 9#define BOR(i, a, b) for(int i=(a); i>=(b); i--) 10#define ft first 11#define sd second 12 13using namespace std; 14using ll = long long; 15using lll = __int128_t; 16using ulll = __uint128_t; 17using ull = unsigned long long; 18using ld = long double; 19using pii = pair<int, int>; 20using pll = pair<ll, ll>; 21using ti3 = tuple<int, int, int>; 22using tl3 = tuple<ll, ll, ll>; 23 24template<typename T> using ve = vector<T>; 25template<typename T> using vve = vector<vector<T>>; 26 27template<class T> bool ckmin(T& a, const T& b) { return b < a ? a = b, 1 : 0; } 28template<class T> bool ckmax(T& a, const T& b) { return a < b ? a = b, 1 : 0; } 29 30const int INF = 987654321; 31const int INF0 = numeric_limits<int>::max(); 32const ll LNF = 987654321987654321; 33const ll LNF0 = numeric_limits<ll>::max(); 34 35int H, W; 36ll dp[11][11][1<<11]; 37 38ll sol(int h, int w, int bit) { 39 if(h==H) return (bit == ((1<<W)-1)); 40 ll &ret = dp[h][w][bit]; 41 if(ret != -1) return ret; 42 int nh = h, nw = w+1; 43 if(nw == W) nh++, nw=0; 44 if(h!=0 and (bit & (1<<(W-1))) == 0) return ret = sol(nh,nw,(bit*2+1)%(1<<W)); 45 ret = sol(nh,nw,(bit*2)%(1<<W)); 46 if(w!=0 and (bit & 1) == 0) ret += sol(nh,nw,((bit+1)*2+1)%(1<<W)); 47 return ret; 48} 49 50int main(void) { 51 ios_base::sync_with_stdio(false); 52 cin.tie(nullptr); 53 cout.tie(nullptr); 54 55 while(true) { 56 cin >> H >> W; 57 if(H==0 and W==0) break; 58 memset(dp, -1, sizeof dp); 59 cout << sol(0,0,0) << endl; 60 } 61 62 63 return 0; 64}
위 포스트는 백준 1787 - 문자열의 주기 예측 의 해설입니다. 결국 부분 문자열에서 가장 짧으면서 일치하는 Prefix와 Suffix를 찾으면 된다. (해당 길이를 전체…
2025/03/05
위 포스트는 백준 1055 - 끝이없음의 해설입니다. 문자열이 재귀적으로 반복하는 것을 알 수 있다. 이때 min과 max의 차이가 최대 100개 정도임을 알 수 있고, 우리는…
2025/03/05
위 포스트는 백준 8872 - 빌라봉 문제의 해설입니다. 위 문제에는 여러 개의 트리가 존재한다. 임의의 2개의 트리를 서로 이을 때 최대 시간이 최소가 되게 하기 위해서는 각…
2025/03/04
위 포스트는 백준 24979 - COW Operations에 대한 해설입니다. 아이디어1# 주어진 Operation을 해보면 아래와 같은 변환이 가능하다는 것을 알 수 있다.…
2025/02/28