으허.. 머리에 쥐나긴했는데.. chatGPT한테 힌트 받고 스스로 풀긴했다 ㄷ
재귀를 통해서 하는건데.. 알아두면 두고두고 써먹을거 같긴하다.
#include <bits/stdc++.h>
using namespace std;
#include <iostream>
#include <algorithm>
#include <string>
using namespace std;
typedef long long ll;
ll length[21];
ll val[21];//val[3]이면 F(3)일때 1의 개수
ll solution_sub(int n, ll l, ll r) {
if (n <= 0) return 1;
ll answer = 0;
if (n == 1) {
for (int i = l; i <= r; i++) {
if (i != 3) answer += 1;
}
return answer;
}
//n에 대해서 5등분 해서 재귀로 들어가면 되지 않을까?
ll lx = (l - 1) / length[n - 1] + 1;
ll rx = (r - 1) / length[n - 1] + 1;
ll nl = l - length[n - 1] * ((l - 1) / length[n - 1]);
ll nr = r - length[n - 1] * ((r - 1) / length[n - 1]);
if (lx == rx) {
if(lx!=3) answer += solution_sub(n - 1, nl, nr);
} else {
//왼쪽
//answer += solution_sub(n - 1, l - length[n-1]*((l-1)/length[n-1]), r - length[n - 1] * ((r - 1) / length[n - 1]));
ll nl = l - length[n - 1] * ((l - 1) / length[n - 1]);
ll nr = r - length[n - 1] * ((r - 1) / length[n - 1]);
ll a = ((l - 1) / length[n - 1] + 1) * length[n - 1];
ll rv = nr; if (r > a) rv = length[n - 1];
if(lx!=3) answer += solution_sub(n - 1, nl, rv);
//오른쪽
a = ((r - 1) / length[n - 1]) * length[n - 1];
ll lv = nl; if (l < a) lv = 1;
if(rx!=3) answer += solution_sub(n - 1, lv, nr);
//중간
for (int i = lx + 1; i < rx; i++) {
if (i != 3) answer += val[n - 1];
}
}
return answer;
}
ll solution(int n, ll l, ll r) {
length[1] = 5; for (int i = 2; i <= 21; i++) length[i] = length[i - 1] * 5;
val[1] = 4; for (int i = 2; i <= 21; i++) val[i] = val[i - 1] * 4;
return solution_sub(n, l, r);
}
int main() {
cout << solution(3, 35, 102) << endl;
// 예시 입력: n = 2, l = 4, r = 17 → 결과는 8이어야 함
cout << solution(2, 4, 17) << endl;
return 0;
}
초기구현.. 거의 한번에 AC받긴함
반응형
'Programming > Problem Solving' 카테고리의 다른 글
python 기본(PS용) (0) | 2025.03.14 |
---|---|
프로그래머스 - 점찍기 (0) | 2025.03.09 |
cph (0) | 2024.07.21 |
double과 관련된 핸들링 (0) | 2021.12.26 |
백준 4103 ATM (0) | 2020.05.05 |