#include using namespace std; #define ll long long #define ld long double #define rep(i, n) for (ll i = 0; i < (ll)(n); i++) #define FOR(i, a, b) for (ll i = (a); i < (ll)(b); i++) #define FORR(i, a, b) for (ll i = (a); i <= (ll)(b); i++) #define repR(i, n) for (ll i = n - 1; i >= 0LL; i--) #define all(v) (v).begin(), (v).end() #define rall(v) (v).rbegin(), (v).rend() #define F first #define S second #define pb push_back #define pu push #define COUT(x) cout << (x) << "\n" #define PQ(x) priority_queue #define PQR(x) priority_queue, greater> #define YES(n) cout << ((n) ? "YES\n" : "NO\n") #define Yes(n) cout << ((n) ? "Yes\n" : "No\n") #define mp make_pair #define sz(x) (ll)(x).size() typedef pair pii; typedef pair pll; typedef tuple tll; using u64 = unsigned long long; using vii = vector; using vvii = vector; using vll = vector; using vb = vector; using vvb = vector; using vvll = vector; using vvvll = vector; using vstr = vector; using vc = vector; using vvc = vector; // const ll MOD = 1e9+7LL; const ll MOD = 998244353LL; const ll INF = 1LL << 60; const double INF_D = numeric_limits::infinity(); template constexpr void printArray(const vector &vec, char split = ' ') { rep(i, vec.size()) { cout << vec[i]; cout << (i == (int)vec.size() - 1 ? '\n' : split); } } template inline bool chmax(T &a, T b) { if (a < b) { a = b; return true; } return false; } template inline bool chmin(T &a, T b) { if (a > b) { a = b; return true; } return false; } ll dx[4] = {0, 1, 0, -1}; ll dy[4] = {1, 0, -1, 0}; bool isIn(ll nx, ll ny, ll h, ll w) { if (nx >= 0 && nx < h && ny >= 0 && ny < w) { return true; } return false; } struct edge { ll to, y, cost; }; int main() { ll n, c, v; cin >> n >> c >> v; vll s(v), t(v), y(v), m(v); rep(i, v) cin >> s[i]; rep(i, v) cin >> t[i]; rep(i, v) cin >> y[i]; rep(i, v) cin >> m[i]; vector> d(n, vector(0)); rep(i, v) { s[i]--; t[i]--; d[s[i]].pb({t[i], y[i], m[i]}); } vvll dist(n, vll(c + 1, INF)); dist[0][c] = 0; priority_queue, vector>, greater>> que; que.push({0, 0, c}); while (que.size()) { auto [cost, now, yen] = que.top(); que.pop(); if (dist[now][yen] < cost) { continue; } for (auto e : d[now]) { if (yen >= e.y && chmin(dist[e.to][yen - e.y], cost + e.cost)) { que.push({cost + e.cost, e.to, yen - e.y}); } } } ll ans = INF; rep(i, c + 1) { chmin(ans, dist[n - 1][i]); } if (ans == INF) ans = -1; cout << ans << endl; } /*cin.tie(0); ios::sync_with_studio(false); next_permutation(v.begin(), v.end()) cout << fixed << setprecision(10); __int128 //ソート済み v.erase(unique(v.begin(), v.end()), v.end()); __builtin_popcountll(i) // maskからnowのビットだけ削除 mask & ~(1 << now) */