結果
問題 | No.90 品物の並び替え |
ユーザー | kongarishisyamo |
提出日時 | 2016-05-01 22:17:22 |
言語 | C++11 (gcc 11.4.0) |
結果 |
AC
|
実行時間 | 2 ms / 5,000 ms |
コード長 | 1,160 bytes |
コンパイル時間 | 514 ms |
コンパイル使用メモリ | 60,704 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-10-05 00:59:52 |
合計ジャッジ時間 | 960 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 1 ms
5,248 KB |
testcase_01 | AC | 2 ms
5,248 KB |
testcase_02 | AC | 1 ms
5,248 KB |
testcase_03 | AC | 1 ms
5,248 KB |
testcase_04 | AC | 2 ms
5,248 KB |
testcase_05 | AC | 1 ms
5,248 KB |
testcase_06 | AC | 1 ms
5,248 KB |
testcase_07 | AC | 1 ms
5,248 KB |
testcase_08 | AC | 1 ms
5,248 KB |
testcase_09 | AC | 2 ms
5,248 KB |
ソースコード
#include<iostream> #include<cmath> using namespace std; #define MAX ((2<<9)+1) #define INF -1000000000 int bitdp[MAX]; int data[9][9]; int powa[10]; void dp(int bit,int n){ bool f[9]; for(int i=0;i<n;i++){ if((bit>>i)%2==0) f[i]=false; else f[i]=true; } for(int i=0;i<n;i++){ if((bit>>i)%2==1){ int tmpbit=bit; tmpbit-=powa[i]; int c=bitdp[tmpbit]; int pc=0; for(int j=0;j<n;j++){ if(!f[j]) pc+=data[i][j]; } //cout<<bit<<","<<i<<","<<bitdp[bit]<<","<<c<<","<<pc<<endl; bitdp[bit]=max(bitdp[bit],c+pc); } } } void make(int n,int c,int bit,int deep,int to,int N){ if(n==0){ if(to==c){ dp(bit,N); } } else{ if(to!=c) make(n-1,c+1,bit+powa[deep],deep+1,to,N); make(n-1,c,bit,deep+1,to,N); } } int main(){ int N,M; int item1,item2,score; int sum[9]={0}; cin>>N>>M; for(int i=0;i<M;i++){ cin>>item1>>item2>>score; data[item1][item2]=score; sum[item1]+=score; } for(int i=0;i<=(2<<9);i++) bitdp[i]=INF; bitdp[0]=0; for(int i=0;i<=N;i++) powa[i]=pow(2.0,i); for(int i=0;i<N;i++) bitdp[powa[i]]=sum[i]; for(int i=2;i<=N;i++){ make(N,0,0,0,i,N); } cout<<bitdp[powa[N]-1]<<endl; }