#include<iostream>
using namespace std;
#include<cstdio>
#define INF 30001
long long int f[INF];
int n,m;
struct Wp{
int v,p;
int vp;
};
Wp wp[26];
void input()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=m;++i)
{
scanf("%d%d",&wp[i].v,&wp[i].p);
wp[i].vp=wp[i].v*wp[i].p;
}
}
void DP()
{
for(int i=1;i<=m;++i)
for(int j=n;j>=wp[i].v;--j)
f[j]=max(f[j],f[j-wp[i].v]+wp[i].vp);
}
int main()
{
input();
DP();
cout<<f[n]<<endl;
return 0;
}