#include <iostream>
#include <algorithm>
using namespace std;
const int N = 20005;
int f[N];
struct Node
{
int s, v, w;
} a[N];
int main()
{
int n, m;
cin >> n >> m;
int v, w;
for (int i = 0; i <= m; i++)
{
int l, h, v, w;
if (i != 0)
{
cin >> l >> h >> v >> w;
int s = l / h;
while (s--)
{
for (int j = n; j >= v; j--)
f[j] = max(f[j], f[j - v] + w);
}
}
else
{
cin >> v >> w;
int s = n / v;
while (s--)
{
for (int j = n; j >= v; j--)
f[j] = max(f[j], f[j - v] + w);
}
}
}
cout << f[n] << "\n";
}