#include <iostream> #include <string> #include <algorithm> #include <vector> #include <iomanip> #include <math.h> #include <numeric> #include <complex> #include <queue> #include <deque> #include <stack> #include <map> #include <unordered_map> #include <set> #include <bitset> #include <functional> #include <assert.h> using ll=long long; #define int ll #define rng(i,a,b) for(int i=int(a);i<int(b);i++) #define rep(i,b) rng(i,0,b) #define gnr(i,a,b) for(int i=int(b)-1;i>=int(a);i--) #define per(i,b) gnr(i,0,b) #define eb emplace_back #define all(x) x.begin(),x.end() #define SZ(x) ((int)x.size()) #define fi first #define se second const int INF = 1e15; using namespace std; template<class T> using vc=vector<T>; template<class T> using vvc=vc<vc<T>>; using pi=pair<int,int>; using vi=vc<int>; template<class T> inline bool chmax(T &a,T b){if(a<b){a=b;return true;}return false;} template<class T> inline bool chmin(T &a,T b){if(a>b){a=b;return true;}return false;} signed main() { cin.tie(0); ios::sync_with_stdio(0); cout<<fixed<<setprecision(20); int N; cin >> N; int Y[N]; rep(i,N) cin >> Y[i]; vvc<int> dp(N+1,vi(11000,INF)); dp[0][0]=0; rep(i,N) { vi a(11000,INF); a[0]=dp[i][0]; rng(j,1,11000) a[j]=min(a[j-1],dp[i][j]); rep(j,11000) { chmin(dp[i+1][j],abs(Y[i]-j)+a[j]); } } int ans=INF; rep(i,11000) chmin(ans,dp[N][i]); cout << ans << endl; }