mod = 998244353 inf = 10 ** 17 def main(): import sys input = sys.stdin.readline N, K = map(int, input().split()) SA = [] for _ in range(N): SA.append(tuple(map(int, input().split()))) dp = [-inf] * (K + 1) dp[0] = 0 for s, a in SA: dp_new = [-inf] * (K + 1) for j in range(K + 1): dp_new[j] = max(dp_new[j], dp[j]) if j + s <= K: dp_new[j + s] = max(dp_new[j + s], dp[j] + a) dp = dp_new ans = 0 for j in range(K+1): ans = max(ans, dp[j]) print(ans) if __name__ == '__main__': main()