#include <iostream>
using namespace std;
int n,V;
const int maxn=1e2+10;
int v[maxn],w[maxn],s[maxn];
int dp[maxn];
int main(){
cin>>n>>V;
for(int i=1; i<=n; i++){
cin>>v[i]>>w[i]>>s[i];
}
for(int i=1; i<=n; i++){
for(int k=1; k<=s[i]; k++){
for(int j=V; j>=v[i]; j--){
dp[j]=max(dp[j], dp[j-v[i]]+w[i]);
}
}
}
cout<<dp[V];
}