| 提出番号 | 1449 |
|---|---|
| 提出者 | square1001 |
| 言語 | C++ |
| 提出日時 | 2018-08-04 12:21:18 |
| 問題名 | (64)Or Plus Max 2 |
| 結果 | MLE |
| 点数 | 78% |
| テストケース | 結果 | 得点 | 実行時間 | メモリ使用量 |
|---|---|---|---|---|
| 1 | AC | 100% | 4ms | 18480KB |
| 2 | AC | 100% | 4ms | 18480KB |
| 3 | AC | 100% | 4ms | 18480KB |
| 4 | AC | 100% | 4ms | 18608KB |
| 5 | AC | 100% | 4ms | 18608KB |
| 6 | AC | 100% | 4ms | 18608KB |
| 7 | AC | 100% | 4ms | 18528KB |
| 8 | AC | 100% | 3ms | 18544KB |
| 9 | AC | 100% | 3ms | 18592KB |
| 10 | AC | 100% | 4ms | 18480KB |
| 11 | AC | 100% | 4ms | 18592KB |
| 12 | AC | 100% | 4ms | 18592KB |
| テストケース | 結果 | 得点 | 実行時間 | メモリ使用量 |
|---|---|---|---|---|
| 13 | AC | 100% | 7ms | 21312KB |
| 14 | AC | 100% | 6ms | 21040KB |
| 15 | AC | 100% | 6ms | 21296KB |
| 16 | AC | 100% | 5ms | 20800KB |
| 17 | AC | 100% | 7ms | 21312KB |
| 18 | AC | 100% | 6ms | 20336KB |
| 19 | AC | 100% | 7ms | 21312KB |
| 20 | AC | 100% | 7ms | 21296KB |
| テストケース | 結果 | 得点 | 実行時間 | メモリ使用量 |
|---|---|---|---|---|
| 21 | AC | 100% | 14ms | 26832KB |
| 22 | AC | 100% | 508ms | 108096KB |
| 23 | AC | 100% | 1349ms | 188000KB |
| 24 | AC | 100% | 2120ms | 263328KB |
| 25 | AC | 100% | 1838ms | 236656KB |
| 26 | AC | 100% | 353ms | 78576KB |
| 27 | AC | 100% | 2093ms | 263328KB |
| 28 | AC | 100% | 59ms | 32736KB |
| 29 | AC | 100% | 2104ms | 263344KB |
| 30 | AC | 100% | 1786ms | 263344KB |
| テストケース | 結果 | 得点 | 実行時間 | メモリ使用量 |
|---|---|---|---|---|
| 31 | TLE | 0% | 20001ms | 0KB |
| 32 | TLE | 0% | 20001ms | 0KB |
| 33 | TLE | 0% | 20002ms | 0KB |
| 34 | TLE | 0% | 20002ms | 0KB |
| 35 | MLE | 0% | 17166ms | 1527920KB |
| 36 | MLE | 0% | 18683ms | 1527920KB |
| 37 | AC | 100% | 430ms | 119424KB |
| 38 | TLE | 0% | 20002ms | 0KB |
| 39 | TLE | 0% | 20002ms | 0KB |
| 40 | TLE | 0% | 20002ms | 0KB |
| 41 | TLE | 0% | 20001ms | 0KB |
#include <map>
#include <vector>
#include <iostream>
using namespace std;
const int mod = 1000000007;
int N, K, D, P, comb[15][15];
map<vector<int>, bool> vis[44][825];
map<vector<int>, int> dp[44][825];
int solve(int dep, int sum, vector<int> v) {
if (dep == N) return sum == K;
if (vis[dep][sum][v]) return dp[dep][sum][v];
int vs = 0, ret = 0;
for (int i = (int)v.size() - 1; i >= -1; --i) {
for (int j = 1; j <= D - vs; ++j) {
vector<int> w(v.begin() + (i + 1), v.end());
w.push_back(j);
int mul = comb[D - vs][j] - (i >= 0 ? comb[D - vs - v[i]][j] : 0);
int res = solve(dep + 1, sum + w.size(), w);
ret = (ret + 1LL * mul * res) % mod;
}
if(i >= 0) vs += v[i];
}
vis[dep][sum][v] = true;
dp[dep][sum][v] = ret;
return ret;
}
int main() {
cin >> N >> K >> P;
while (1 << D < P) ++D;
for (int i = 0; i <= D; ++i) {
comb[i][0] = 1;
for (int j = 1; j <= i; ++j) {
comb[i][j] = comb[i - 1][j] + comb[i - 1][j - 1];
}
}
int ret = solve(0, 0, vector<int>());
cout << ret << '\n';
return 0;
}