結果
問題 | No.1 道のショートカット |
ユーザー |
![]() |
提出日時 | 2019-06-08 18:34:18 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 3 ms / 5,000 ms |
コード長 | 1,101 bytes |
コンパイル時間 | 1,832 ms |
コンパイル使用メモリ | 177,808 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-07-20 16:39:31 |
合計ジャッジ時間 | 3,041 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 40 |
ソースコード
#include <bits/stdc++.h> using namespace std; typedef long long ll; typedef pair<int,int> pii; #define pb push_back #define mp make_pair #define rep(i,n) for(int i=0;i<(n);++i) constexpr int mod=1000000007; constexpr int mod1=998244353; vector<int> dx={0,-1,0,1},dy={1,0,-1,0}; int inf=1000000000; struct edge{ int to,cost,m; }; int main(){ cin.tie(0); ios::sync_with_stdio(false); int n,c,v;cin >> n >> c >> v; vector<vector<edge>> g(n,vector<edge>()); vector<int> s(v),t(v),y(v),m(v); rep(i,v) cin >> s.at(i); rep(i,v) cin >> t.at(i); rep(i,v) cin >> y.at(i); rep(i,v) cin >> m.at(i); rep(i,v){ edge e; e.to=t.at(i)-1; e.cost=y.at(i); e.m=m.at(i); g.at(s.at(i)-1).pb(e); } vector<vector<int>> dp(n+1,vector<int>(c+1,inf)); dp[0][0]=0; rep(i,n){ rep(j,c){ if(dp[i][j]==inf) continue; rep(k,g.at(i).size()){ if(j+g.at(i).at(k).cost<=c) dp[g.at(i).at(k).to][j+g.at(i).at(k).cost]=min(dp[g.at(i).at(k).to][j+g.at(i).at(k).cost],dp[i][j]+g.at(i).at(k).m); } } } int ans=inf; rep(i,c+1) ans=min(ans,dp[n-1][i]); if(ans==inf) ans=-1; cout << ans << endl; }