#include<bits/stdc++.h>
using namespace std;
template <typename T> bool maximize(T &res, const T &val){if(res < val) return res = val, true; return false;}
template <typename T> bool minimize(T &res, const T &val){if(res > val) return res = val, true; return false;}
#define ll long long
#define fi first
#define se second
#define pb push_back
#define FOR(i, a, b) for(int i = (a), _b = (b); i <= _b; i++)
#define FORD(i, b, a) for(int i = (b), _a = (a); i >= _a; i--)
#define REP(i, n) for(int i = 0, _n = (n); i < _n; i++)
#define C make_pair
#define MASK(i) (1LL << (i))
#define TURN_ON(i, x) ((x) | MASK(i))
#define TURN_OFF(i, x) ((x) & ~MASK(i))
#define RE(i, x) ((x) ^ MASK(i))
const ll mod = 1e9 + 7;
const ll INF = 1e8;
const int maxn = 1e5 + 5;
typedef pair<double, double> pi;
typedef pair<int, pair<int,int>> pii;
typedef pair<ll, ll> pl;
typedef pair<ll, pair<ll,ll>>pll;
struct edge{
int u,v,w;
edge(int u = 0, int v = 0, int w = 0)
{
this->u = u;
this->v = v;
this->w = w;
}
};
struct matrix{
ll val[3][3];
matrix(){
memset(val, 0, sizeof(val));
}
};
const int N = 1e4 + 10;
ll n, c, h[N], ans = +INF;
void nhap(){
cin >> n >> c;
FOR(i, 1, n) cin >> h[i];
}
namespace sub2{
const int limit = 110;
bool check(){
FOR(i, 1, n) if(h[i] > 100) return 0;
return n <= 1000;
}
ll dp[1010][120];
void solve(){
FOR(i, 1, n) FOR(j, 0, limit) dp[i][j] = +INF;
FOR(i, h[1], limit)
dp[1][i] = 1LL * (i - h[1]) * 1LL * (i - h[1]);
FOR(i, 2, n) FOR(j, h[i], limit){
FOR(k, h[i - 1], limit){
if(dp[i - 1][k] == +INF) continue;
minimize(dp[i][j], dp[i - 1][k] + 1LL * abs(j - k) * c + 1LL * (j - h[i]) * 1LL * (j - h[i]));
}
}
FOR(i, h[n], limit) minimize(ans, dp[n][i]);
cout << ans;
}
}
namespace sub3{
const int limit = 1e3 + 10;
ll dp[10010][limit + 20], min1V[10010][limit + 20], min2V[10010][limit + 20], ans = +INF;
void solve(){
FOR(i, 1, n) FOR(j, 0, limit + 1){
dp[i][j] = +INF;
min1V[i][j] = +INF;
min2V[i][j] = +INF;
}
FOR(i, h[1], limit)
dp[1][i] = 1LL * (i - h[1]) * 1LL * (i - h[1]);
FOR(i, 2, n){
FOR(j, 1, limit) min1V[i - 1][j] = min(min1V[i - 1][j - 1], dp[i - 1][j] - c * j);
FORD(j, limit, 1) min2V[i - 1][j] = min(min2V[i - 1][j + 1], dp[i - 1][j] + c * j);
FOR(j, h[i], limit){
dp[i][j] = min(1LL * min1V[i - 1][j] + 1LL * c * j, 1LL * min2V[i - 1][j + 1] - 1LL * c * j) + 1LL * (j - h[i]) * 1LL * (j - h[i]);
}
}
FOR(i, h[n], limit) minimize(ans, dp[n][i]);
cout << ans;
}
}
int main(){
ios_base::sync_with_stdio(0);
cin.tie(0); cout.tie(0);
nhap();
sub3::solve();
return 0;
}
I2luY2x1ZGU8Yml0cy9zdGRjKysuaD4KCnVzaW5nIG5hbWVzcGFjZSBzdGQ7Cgp0ZW1wbGF0ZSA8dHlwZW5hbWUgVD4gYm9vbCBtYXhpbWl6ZShUICZyZXMsIGNvbnN0IFQgJnZhbCl7aWYocmVzIDwgdmFsKSByZXR1cm4gcmVzID0gdmFsLCB0cnVlOyByZXR1cm4gZmFsc2U7fQp0ZW1wbGF0ZSA8dHlwZW5hbWUgVD4gYm9vbCBtaW5pbWl6ZShUICZyZXMsIGNvbnN0IFQgJnZhbCl7aWYocmVzID4gdmFsKSByZXR1cm4gcmVzID0gdmFsLCB0cnVlOyByZXR1cm4gZmFsc2U7fQoKI2RlZmluZSBsbCBsb25nIGxvbmcKI2RlZmluZSBmaSBmaXJzdAojZGVmaW5lIHNlIHNlY29uZAojZGVmaW5lIHBiIHB1c2hfYmFjawojZGVmaW5lIEZPUihpLCBhLCBiKSBmb3IoaW50IGkgPSAoYSksIF9iID0gKGIpOyBpIDw9IF9iOyBpKyspCiNkZWZpbmUgRk9SRChpLCBiLCBhKSBmb3IoaW50IGkgPSAoYiksIF9hID0gKGEpOyBpID49IF9hOyBpLS0pCiNkZWZpbmUgUkVQKGksIG4pIGZvcihpbnQgaSA9IDAsIF9uID0gKG4pOyBpIDwgX247IGkrKykKI2RlZmluZSBDIG1ha2VfcGFpcgojZGVmaW5lIE1BU0soaSkgKDFMTCA8PCAoaSkpCiNkZWZpbmUgVFVSTl9PTihpLCB4KSAoKHgpIHwgTUFTSyhpKSkKI2RlZmluZSBUVVJOX09GRihpLCB4KSAoKHgpICYgfk1BU0soaSkpCiNkZWZpbmUgUkUoaSwgeCkgKCh4KSBeIE1BU0soaSkpCgpjb25zdCBsbCBtb2QgPSAxZTkgKyA3Owpjb25zdCBsbCBJTkYgPSAxZTg7CmNvbnN0IGludCBtYXhuID0gMWU1ICsgNTsKdHlwZWRlZiBwYWlyPGRvdWJsZSwgZG91YmxlPiBwaTsKdHlwZWRlZiBwYWlyPGludCwgcGFpcjxpbnQsaW50Pj4gcGlpOwp0eXBlZGVmIHBhaXI8bGwsIGxsPiBwbDsKdHlwZWRlZiBwYWlyPGxsLCBwYWlyPGxsLGxsPj5wbGw7CgpzdHJ1Y3QgZWRnZXsKICAgIGludCB1LHYsdzsKICAgIGVkZ2UoaW50IHUgPSAwLCBpbnQgdiA9IDAsIGludCB3ID0gMCkKICAgIHsKICAgICAgICB0aGlzLT51ID0gdTsKICAgICAgICB0aGlzLT52ID0gdjsKICAgICAgICB0aGlzLT53ID0gdzsKICAgIH0KfTsKc3RydWN0IG1hdHJpeHsKICAgIGxsIHZhbFszXVszXTsKICAgIG1hdHJpeCgpewogICAgICAgIG1lbXNldCh2YWwsIDAsIHNpemVvZih2YWwpKTsKICAgIH0KfTsKCmNvbnN0IGludCBOID0gMWU0ICsgMTA7CgpsbCBuLCBjLCBoW05dLCBhbnMgPSArSU5GOwoKdm9pZCBuaGFwKCl7CgljaW4gPj4gbiA+PiBjOwoJRk9SKGksIDEsIG4pIGNpbiA+PiBoW2ldOwp9Cm5hbWVzcGFjZSBzdWIyewoJY29uc3QgaW50IGxpbWl0ID0gMTEwOwoJYm9vbCBjaGVjaygpewoJCUZPUihpLCAxLCBuKSBpZihoW2ldID4gMTAwKSByZXR1cm4gMDsKCQlyZXR1cm4gbiA8PSAxMDAwOwoJfQoJbGwgZHBbMTAxMF1bMTIwXTsKCXZvaWQgc29sdmUoKXsKCQlGT1IoaSwgMSwgbikgRk9SKGosIDAsIGxpbWl0KSBkcFtpXVtqXSA9ICtJTkY7CgkJRk9SKGksIGhbMV0sIGxpbWl0KQoJCQlkcFsxXVtpXSA9IDFMTCAqIChpIC0gaFsxXSkgKiAxTEwgKiAoaSAtIGhbMV0pOwoJCUZPUihpLCAyLCBuKSBGT1IoaiwgaFtpXSwgbGltaXQpewoJCQlGT1IoaywgaFtpIC0gMV0sIGxpbWl0KXsKCQkJCWlmKGRwW2kgLSAxXVtrXSA9PSArSU5GKSBjb250aW51ZTsKCQkJCW1pbmltaXplKGRwW2ldW2pdLCBkcFtpIC0gMV1ba10gKyAxTEwgKiBhYnMoaiAtIGspICogYyArIDFMTCAqIChqIC0gaFtpXSkgKiAxTEwgKiAoaiAtIGhbaV0pKTsKCQkJfQoJCX0KCQlGT1IoaSwgaFtuXSwgbGltaXQpIG1pbmltaXplKGFucywgZHBbbl1baV0pOwoJCWNvdXQgPDwgYW5zOwoJfQp9Cm5hbWVzcGFjZSBzdWIzewoJY29uc3QgaW50IGxpbWl0ID0gMWUzICsgMTA7CglsbCBkcFsxMDAxMF1bbGltaXQgKyAyMF0sIG1pbjFWWzEwMDEwXVtsaW1pdCArIDIwXSwgbWluMlZbMTAwMTBdW2xpbWl0ICsgMjBdLCBhbnMgPSArSU5GOwoJCgl2b2lkIHNvbHZlKCl7CgkJRk9SKGksIDEsIG4pIEZPUihqLCAwLCBsaW1pdCArIDEpewoJCQlkcFtpXVtqXSA9ICtJTkY7CgkJCW1pbjFWW2ldW2pdID0gK0lORjsKCQkJbWluMlZbaV1bal0gPSArSU5GOwoJCX0KCQlGT1IoaSwgaFsxXSwgbGltaXQpIAoJCQlkcFsxXVtpXSA9IDFMTCAqIChpIC0gaFsxXSkgKiAxTEwgKiAoaSAtIGhbMV0pOwoJCUZPUihpLCAyLCBuKXsKCQkJRk9SKGosIDEsIGxpbWl0KSBtaW4xVltpIC0gMV1bal0gPSBtaW4obWluMVZbaSAtIDFdW2ogLSAxXSwgZHBbaSAtIDFdW2pdIC0gYyAqIGopOwoJCQlGT1JEKGosIGxpbWl0LCAxKSBtaW4yVltpIC0gMV1bal0gPSBtaW4obWluMlZbaSAtIDFdW2ogKyAxXSwgZHBbaSAtIDFdW2pdICsgYyAqIGopOwoJCQlGT1IoaiwgaFtpXSwgbGltaXQpewoJCQkJZHBbaV1bal0gPSBtaW4oMUxMICogbWluMVZbaSAtIDFdW2pdICsgMUxMICogYyAqIGosIDFMTCAqIG1pbjJWW2kgLSAxXVtqICsgMV0gLSAxTEwgKiBjICogaikgKyAxTEwgKiAoaiAtIGhbaV0pICogMUxMICogKGogLSBoW2ldKTsKCQkJfQoJCX0KCQlGT1IoaSwgaFtuXSwgbGltaXQpIG1pbmltaXplKGFucywgZHBbbl1baV0pOwoJCWNvdXQgPDwgYW5zOwoJfQp9CmludCBtYWluKCl7CiAgICBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKDApOwogICAgY2luLnRpZSgwKTsgY291dC50aWUoMCk7CiAgICBuaGFwKCk7CiAgICBzdWIzOjpzb2x2ZSgpOwogICAgcmV0dXJuIDA7Cn0K