#include<bits/stdc++.h>
using namespace std;
long long n,t;
struct cook{
long long a,b,c;
}food[107];
long long dp[100007];
bool cmp(cook x,cook y){
return y.bx.c<x.by.c;
}
long long ans;
int main(){
cin>>t>>n;
for(int i=1;i<=n;i++){
cin>>food[i].a;
}
for(int i=1;i<=n;i++){
cin>>food[i].b;
}
for(int i=1;i<=n;i++){
cin>>food[i].c;
}
sort(food+1,food+1+n,cmp);
for(int i=1;i<=n;i++){
for(int j=t;j>=food[i].c;j--){
dp[j]=max(dp[j],dp[j-food[i].c]+food[i].a-food[i].b*j);
}
}
for(int i=1;i<=t;i++){
ans=max(ans,dp[i]);
}
cout<<ans;
return 0;
}