結果
| 問題 | 
                            No.90 品物の並び替え
                             | 
                    
| コンテスト | |
| ユーザー | 
                             pasoconhoshii
                         | 
                    
| 提出日時 | 2019-02-11 16:06:31 | 
| 言語 | C++11(廃止可能性あり)  (gcc 13.3.0)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 100 ms / 5,000 ms | 
| コード長 | 731 bytes | 
| コンパイル時間 | 1,088 ms | 
| コンパイル使用メモリ | 163,568 KB | 
| 実行使用メモリ | 5,376 KB | 
| 最終ジャッジ日時 | 2024-07-18 12:08:39 | 
| 合計ジャッジ時間 | 1,663 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge3 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 1 | 
| other | AC * 9 | 
ソースコード
// FROM : https://yukicoder.me/submissions/306204
//
#include <bits/stdc++.h>
#include <iostream>
using namespace std;
struct Data
{
  int item1, item2, score;
};
int main()
{
  long long N,M;
  cin >> N >> M;
  vector<Data> scores(M);
  vector<long long> v(N);
  for (int i=0; i < N; i++) {
    v[i] = i;
  }
  for (long long i=0; i<M; i++) {
    int a,b,c;
    struct Data d;
    cin >> d.item1 >> d.item2 >> d.score;
    scores[i] = d;
  }
  long long ans = 0;
  do {
    long long  t = 0;
    for (int i = 0; i<M; i++) {
      if (v[scores[i].item1] < v[scores[i].item2]) 
        t += scores[i].score;
    }
    ans = max(ans, t);
  } while (next_permutation(v.begin(), v.end()));
  cout << ans << endl;
  return 0;
}
            
            
            
        
            
pasoconhoshii