// #include #include #include #define INF (1 << 26) using namespace std; int main() { int N, C, V; scanf("%d", &N); scanf("%d", &C); scanf("%d", &V); int S[V], T[V], Y[V], M[V]; for (int i = 0; i < V; i++) { scanf("%d", &S[i]); } for (int i = 0; i < V; i++) { scanf("%d", &T[i]); } for (int i = 0; i < V; i++) { scanf("%d", &Y[i]); } for (int i = 0; i < V; i++) { scanf("%d", &M[i]); } int p[V]; for (int i = 0; i < V; i++) { p[i] = i; } sort(p, p + V, [&](int a, int b) { return S[a] < S[b]; }); long dp[N + 1][C + 1]; for (int i = 0; i < N + 1; i++) { for (int j = 0; j < C + 1; j++) { dp[i][j] = INF; } } dp[1][C] = 0; for (int i = 0; i < V; i++) { int ptr = p[i]; for (int j = 0; j < C + 1; j++) { if (Y[ptr] + j <= C) { dp[T[ptr]][j] = min(dp[T[ptr]][j], dp[S[ptr]][j + Y[ptr]] + M[ptr]); } } } long min_time = INF; for (int i = 0; i < C + 1; i++) { min_time = min(min_time, dp[N][i]); } if (min_time == INF) { printf("-1\n"); } else { printf("%ld\n", min_time); } return 0; }