N,D,K = map(int,input().split()) A = list(map(int,input().split())) C = list(map(int,input().split())) INF = 1 << 60 dp = [[-INF] * (K + 1) for i in range(D + 1)] # dp[i][j] = i個採用して、Cの合計はjのときの最大の満足度。ただしj > KのときはK dp[0][0] = 0 for k in range(N): # 検討する問題 for i in range(D - 1, -1, -1): # 採用する問題数。すでにD個選ばれている場合は対象外 for j in range(K, -1, -1): # 美しさの合計 if dp[i][j] == -INF: continue dp[i + 1][min(j + C[k], K)] = max(dp[i + 1][min(j + C[k], K)], dp[i][j] + A[k]) if dp[D][K] == -INF: print("No") else: print(dp[D][K])