#include<bits/stdc++.h>
using namespace std;
const int N=65;
int f[N],w[N],v[N],p[N][N];
int n,m,ans,k;
int main(){
cin>>n>>m;
for(int i=1;i<=m;i++) {
cin>>w[i]>>v[i]>>k;
if(k!=0) {
if(p[k][1]==0) p[k][1]=i;
else p[k][2]=i;
}
}
for(int i=1;i<=m;i++){
for(int j=n;j>=w[i];j--){
if(j-w[i]>=0)
f[j]=max(f[j],f[j-w[i]]+w[i]*v[i]);
if(p[i][1]!=0){
if(j-w[i]-w[p[i][1]]>=0)
f[j]=max(f[j],f[j-w[i]-w[p[i][1]]]+w[i]*v[i]+w[p[i][1]]*v[p[i][1]]);
if(p[i][2]!=0){
if(j-w[i]-w[p[i][2]]>=0)
f[j]=max(f[j],f[j-w[i]-w[p[i][2]]]+w[i]*v[i]+w[p[i][2]]*v[p[i][2]]);
if(j-w[i]-w[p[i][1]]-w[p[i][2]]>=0)
f[j]=max(f[j],f[j-w[i]-w[p[i][1]]-w[p[i][2]]]+w[i]*v[i]+w[p[i][1]]*v[p[i][1]]+w[p[i][2]]*v[p[i][2]]);
}
}
}
}
for(int i=0;i<=n;i++) ans=max(ans,f[i]);
cout<<ans;
return 0;
}