提出番号 | 2188 |
---|---|

提出者 | hamuhei4869 |

言語 | C++ |

提出日時 | 2018-11-02 17:07:17 |

問題名 | (70)アルゴリズムのお勉強 |

結果 | WA |

点数 | 0% |

テストケース | 結果 | 得点 | 実行時間 | メモリ使用量 |
---|---|---|---|---|

1 | WA | 0% | 2ms | 8720KB |

2 | WA | 0% | 1ms | 8512KB |

3 | WA | 0% | 2ms | 7872KB |

4 | WA | 0% | 1ms | 8464KB |

5 | WA | 0% | 2ms | 8448KB |

6 | WA | 0% | 2ms | 8704KB |

7 | WA | 0% | 2ms | 8432KB |

8 | WA | 0% | 2ms | 8608KB |

9 | WA | 0% | 2ms | 8688KB |

10 | WA | 0% | 2ms | 8032KB |

11 | WA | 0% | 2ms | 7600KB |

12 | WA | 0% | 2ms | 8304KB |

13 | WA | 0% | 2ms | 7920KB |

14 | WA | 0% | 2ms | 7264KB |

15 | WA | 0% | 2ms | 8224KB |

16 | WA | 0% | 2ms | 8160KB |

17 | WA | 0% | 1ms | 8304KB |

18 | WA | 0% | 1ms | 7792KB |

19 | WA | 0% | 3ms | 8208KB |

20 | WA | 0% | 2ms | 8016KB |

21 | WA | 0% | 2ms | 8704KB |

22 | WA | 0% | 4ms | 8448KB |

23 | WA | 0% | 2ms | 8688KB |

24 | WA | 0% | 6ms | 7648KB |

25 | WA | 0% | 3ms | 8304KB |

26 | WA | 0% | 4ms | 7936KB |

27 | WA | 0% | 6ms | 7568KB |

28 | WA | 0% | 2ms | 8736KB |

29 | WA | 0% | 23ms | 15648KB |

30 | WA | 0% | 3ms | 8464KB |

```
#include <bits/stdc++.h>
const int INF = 1e9;
const int MODk = 1e9+7;
using LL = long long;
const LL LINF = 1e18;
const double EPS = 1e-10;
using namespace std;
#define COUT(v) cout<<(v)<<endl
#define COUTDOUBLE(v) cout << std::setprecision(10)<<(v)<<endl;
#define CIN(n) int(n);cin >> (n)
#define LCIN(n) LL(n);cin >> (n)
#define SCIN(n) string(n);cin >> (n)
#define YES(n) cout<<((n)? "YES" : "NO")<<endl
#define Yes(n) cout<<((n)? "Yes" : "No")<<endl
#define POSSIBLE(n) cout << ((n) ? "POSSIBLE" : "IMPOSSIBLE" ) << endl
#define Possible(n) cout << ((n) ? "Possible" : "Impossible" ) <<endl
#define FOR(i,a,b) for(int i=(a);i<(b);++i)
#define REP(i,n) for(int i=0;i<(n);++i)
#define REPR(i,n) for(int i=n;i>=0;i--)
#define FOREACH(x,a) for(auto& (x) : (a) )
#define ALL(obj) (obj).begin(),(obj).end()
#define P pair<LL,LL>
#define I vector<int>
#define pb(v) push_back(v)
#define V vector
#define rt return
#define rmsame(a) sort(ALL(a)),a.erase(unique(ALL(a)), a.end())
#define ENDL cout<<endl
typedef string::const_iterator State;
class PalseError {};
class Edge{
public:
int from,to,value;
Edge(LL a,LL b,LL c){
from = a;
to = b;
value = c;
}
Edge(LL a,LL b){
from = a;
to = b;
}
};
int N;
int dist[21][21];
int dp[(1<<20) + 1][21]; // dpテーブルは余裕をもったサイズにする
int rec(int bit, int v)
{
// すでに探索済みだったらリターン
if (dp[bit][v] != -1) return dp[bit][v];
// 初期値
if (bit == (1<<v)) {
return dp[bit][v] = 0;
}
// 答えを格納する変数
int res = INF;
// bit の v を除いたもの
int prev_bit = bit & ~(1<<v);
// v の手前のノードとして u を全探索
for (int u = 0; u < N; ++u) {
if (!(prev_bit & (1<<u))) continue; // u が prev_bit になかったらダメ
// 再帰的に探索
if (res > rec(prev_bit, u) + dist[u][v]) {
res = rec(prev_bit, u) + dist[u][v];
}
}
return dp[bit][v] = res; // メモしながらリターン
}
int main(){
cin >> N;
I vec;
REP(a,N){
CIN(b);
vec.push_back(b);
}
REP(a,N){
REP(b,N){
CIN(c);
dist[a][b] = max(vec.at(b) - c,0);
}
}
for(int bit = 0;bit < (1<<N);bit++){
for(int v = 0; v < N;v++){
dp[bit][v]=-1;
}
}
int res = INF;
for(int v = 0;v < N;v++){
if(res > rec((1<<N)-1,v) + vec.at(v)){
res = rec((1<<N)-1, v) + vec.at(v);
}
}
COUT(res);
rt 0;
}
```