#include<bits/stdc++.h>
using namespace std;
const long long MAXN=1000001;
struct dp{
int v;
int p;
}a[MAXN];
int bag,n,ans;
void dfs(int x,int y,int z){
if(z>n){
ans=max(ans,x);
return;
}
if(y>=bag)
return;
ans=max(ans,x);
dfs(x,y,z+1);
dfs(x+a[z].p,y+a[z].v,z+1);
}
int main(){
ios::sync_with_stdio(false);
cin>>bag>>n;
for(register int i=1;i<=n;i++){
cin>>a[i].v>>a[i].p;
a[i].p*=a[i].v;
}
dfs(0,0,0);
cout<<ans<<endl;
}
求dalao解答