結果

問題 No.845 最長の切符
コンテスト
ユーザー SSRS
提出日時 2020-11-20 18:24:19
言語 C++14
(gcc 15.2.0 + boost 1.89.0)
コンパイル:
g++-15 -O2 -lm -std=c++14 -Wuninitialized -DONLINE_JUDGE -o a.out _filename_
実行:
./a.out
結果
WA  
実行時間 -
コード長 668 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 401 ms
コンパイル使用メモリ 84,960 KB
実行使用メモリ 7,976 KB
最終ジャッジ日時 2026-04-03 14:17:33
合計ジャッジ時間 1,841 ms
ジャッジサーバーID
(参考情報)
judge2_0 / judge3_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample WA * 3
other WA * 27
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

#include <iostream>
#include <vector>
#include <utility>
using namespace std;
int main(){
	int N, M;
	cin >> N >> M;
	vector<vector<pair<int, int>>> E(N);
	for (int i = 0; i < M; i++){
		int a, b, c;
		cin >> a >> b >> c;
		a--;
		b--;
		E[a].push_back(make_pair(c, b));
		E[b].push_back(make_pair(c, a));
	}
	vector<int> dp(1 << N, 0);
	for (int i = 1; i < (1 << N); i++){
		for (int j = 0; j < N; j++){
			if (i >> j & 1){
				for (auto P : E[j]){
					int k = P.second;
					if (!(i >> k & 1)){
						dp[i | (1 << k)] = max(dp[i | (1 << k)], dp[i] + P.first);
					}
				}
			}
		}
	}
	int ans = 0;
	for (int i = 0; i < (1 << N); i++){
		ans = max(ans, dp[i]);
	}
}
0