#include <bits/stdc++.h>
using namespace std;
const int N = 5010, M = 100010, inf = 0x3f3f3f3f;
int S, T;
int r[N];
int h[N], e[M], f[M], w[M], ne[M], idx;
int q[N], d[N], pre[N], incf[N];
bool st[N];
void add(int a, int b, int c, int d)
{
e[idx] = b, f[idx] = c, w[idx] = d, ne[idx] = h[a], h[a] = idx ++ ;
e[idx] = a, f[idx] = 0, w[idx] = -d, ne[idx] = h[b], h[b] = idx ++ ;
}
bool spfa()
{
memset(incf, 0, sizeof incf);
memset(d, 0x3f, sizeof d);
int hh = 0, tt = 1;
q[0] = S, d[S] = 0, incf[S] = inf;
while (hh != tt)
{
int t = q[hh ++ ];
if (hh == N) hh = 0;
st[t] = false;
for (int i = h[t]; ~i; i = ne[i])
{
int j = e[i];
if (f[i] && d[j] > d[t] + w[i])
{
d[j] = d[t] + w[i];
pre[j] = i;
incf[j] = min(incf[t], f[i]);
if (!st[j])
{
q[tt ++ ] = j;
if (tt == N) tt = 0;
st[j] = true;
}
}
}
}
return incf[T] > 0;
}
void EK(int& flow, int& cost)
{
flow = cost = 0;
while (spfa())
{
flow += incf[T], cost += incf[T] * d[T];
for (int i = T; i != S; i = e[pre[i] ^ 1] )
{
f[pre[i]] -= incf[T];
f[pre[i] ^ 1] += incf[T];
}
}
}
int main()
{
int day, p, m, f, n, s;
scanf("%d%d%d%d%d%d", &day, &p, &m, &f, &n, &s);
S = 0, T = day * 2 + 1;
memset(h, -1, sizeof h);
for (int i = 1; i <= day; i ++ )
{
scanf("%d", &r[i]);
add(S, i, r[i], 0);
add(S, day + i, inf, p);
add(day + i, T, r[i], 0);
if (i > 1) add(day + i - 1, day + i, inf, 0);
if (i > m) add(i - m, day + i, inf, f);
if (i > n) add(i - n, day + i, inf, s);
}
int flow, cost;
EK(flow, cost);
printf("%d\n", cost);
return 0;
}