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 29
| #include <bits/stdc++.h> using namespace std;
int n, k; int ans; int sum;
void dfs(int x, int start) { if (x == k+1) { if (sum == n) ans++; return; } for (int i = start; sum+i*(k-x+1) <= n; i++) { sum+=i; dfs(x+1,i); sum-=i; } }
int main() { freopen("data.in","r",stdin); freopen("dfs.out","w",stdout); cin >> n >> k; dfs(1,1); cout << ans; return 0; }
|