結果

提出番号 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;
}