0
1
mirror of https://git.sb/baoshuo/OI-codes.git synced 2024-09-20 10:45:25 +00:00
OI-codes/Luogu/problem/P1679/P1679.cpp
2021-01-02 15:30:52 +08:00

35 lines
516 B
C++

#include <bits/stdc++.h>
using namespace std;
int n, ans = 999999;
void dfs(int cnt, int k, int last) {
if (k > ans) {
return;
}
if (cnt > n) {
return;
}
if (cnt == n) {
ans = min(ans, k);
return;
}
int i = last;
while (i*i*i*i <= n - cnt) {
i++;
}
while (i >= last) {
dfs(cnt + i * i * i * i, k + 1, i);
i--;
}
return;
}
int main() {
cin >> n;
dfs(0, 0, 1);
cout << ans << endl;
return 0;
}