#include<iostream>
#include<algorithm>
using namespace std;
const int N=120010,M=2010;
int v[N],w[N];
int dp[M];
int n,m,cut;
int main(){
cin>>n>>m;
for(int i=1;i<=n;i++){
int a,b,s;
cin>>a>>b>>s;
int k=1;
for(;k<=s;k*=2){
v[++cut]=a*k;
w[cut]=b*k;
s-=k;
}
if(s>0){
v[++cut]=a*s;
w[cut]=b*s;
}
}
for(int i=1;i<=cut;i++)
for(int j=m;j>=v[i];j--)
dp[j]=max(dp[j],dp[j-v[i]]+w[i]);
cout<<dp[m]<<endl;
return 0;
}