#include using namespace std; #define repeat(i, n) for(int i=0; i<(n); i++) int memo[101][101]; const int inf=1e8; int main(){ int gx, gy, N, F; cin>> gx>> gy>> N>> F; int dx[N], dy[N], c[N]; for(int i=0; i> dx[i]>> dy[i]>> c[i]; repeat(x, 101){ repeat(y, 101){ if(x==0&&y==0) memo[x][y]=0; else memo[x][y]=inf; } } repeat(i, N){ if(c[i]>(dx[i]+dy[i])*F) continue; repeat(x, gx+1){ repeat(y, gy+1){ if(memo[x][y]==inf) continue; if(x+dx[i]>gx||x+dy[i]>gy) continue; memo[x+dx[i]][y+dy[i]] =min(memo[x+dx[i]][y+dy[i]], memo[x][y]+c[i]); } } } int C=inf; repeat(x, gx+1){ repeat(y, gx+1){ if(memo[x][y]==inf) continue; if(x==gx&&y==gy) continue; int _c=F*((gx-x)+(gy-y)); _c+=memo[x][y]; C=min(C, _c); } } cout<< C<< endl; return 0; }