#include <bits/stdc++.h>
using namespace std;
#define all(x) (x).begin(), (x).end()
typedef long long ll;
const ll INF = 1e18;
const int N = 1e5 + 10, LOG = 18;
ll a[N], dp[N], ndp[N];
int n, m, K;
void solve() {
  cin >> n >> m >> K;
  for (int i = 1; i <= n; i++) {
    cin >> a[i];
    dp[i] = a[i];
  }
  for (int k = 2; k <= K; k++) {
    ndp[1] = -INF;
    deque<ll> q;
    q.push_back(dp[1]);
    for (int i = 2; i <= n; i++) {
      int l = max(1, i - m), r = i - 1;
      ll upd = q.front();
      ndp[i] = upd + k * 1LL * a[i];
      while (!q.empty() && q.back() < dp[i])
        q.pop_back();
      q.push_back(dp[i]);
      if (1 <= i - m && !q.empty() && q.front() == dp[i - m])
        q.pop_front();
    }
    for (int i = 1; i <= n; i++) {
      dp[i] = ndp[i];
    }
  }
  cout << *max_element(dp + 1, dp + 1 + n);
}
int main() {
  ios::sync_with_stdio(NULL), cin.tie(0), cout.tie(0);
  cout.setf(ios::fixed), cout.precision(20);
  solve();
}
