#include<bits/stdc++.h>
using namespace std;
int m;
int t;
int tv[100][2];
int dp[101][1001];
int solve()
{
for(int i=1;i<=m;i++){
for(int j=1;j<=t;j++){
if(j-tv[i][0]>=0)dp[i][j]=max(dp[i-1][j-tv[i][0]]+tv[i][1],dp[i-1][j]);
else dp[i][j]=dp[i-1][j];
}
}
return dp[m][t];
}
int main()
{
cin>>t>>m;
for(int i=0;i<m;i++){
cin>>tv[i][0]>>tv[i][1];
}
cout<<solve();
}