#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define pi (4*atan(1.0))
#define eps 1e-14
const int N=2e5+10,M=4e6+10,inf=1e9+10,mod=1e9+7;
const ll INF=1e18+10;
struct is
{
int l,r,v,si,rnd,w;//v 权值 rnd 堆的优先级 w为v的个数
} tree[N];
int n,sz,root,ans,ans1;
void update(int pos)
{
tree[pos].si=tree[tree[pos].l].si+tree[tree[pos].r].si+tree[pos].w;
}
void lturn(int &pos)
{
int t=tree[pos].r;
tree[pos].r=tree[t].l;
tree[t].l=pos;
tree[t].si=tree[pos].si;
update(pos);
pos=t;
}
void rturn(int &pos)
{
int t=tree[pos].l;
tree[pos].l=tree[t].r;
tree[t].r=pos;
tree[t].si=tree[pos].si;
update(pos);
pos=t;
}
void pushin(int &k,int x)
{
if(k==0)
{
sz++;
k=sz;
tree[k].w=tree[k].si=1;
tree[k].rnd=rand();
tree[k].v=x;
return;
}
tree[k].si++;
if(tree[k].v==x)tree[k].w++;
else if(tree[k].v>x)
{
pushin(tree[k].l,x);
if(tree[tree[k].l].rnd>tree[k].rnd)
rturn(k);
}
else
{
pushin(tree[k].r,x);
if(tree[tree[k].r].rnd>tree[k].rnd)
lturn(k);
}
}
void query(int pos,int x)
{
if(pos==0)return;
if(tree[pos].v<=x)
{
ans=tree[pos].v;
query(tree[pos].r,x);
}
else query(tree[pos].l,x);
}
void query1(int pos,int x)
{
if(pos==0)return;
if(tree[pos].v>x)
{
ans1=tree[pos].v;
query1(tree[pos].l,x);
}
else
query1(tree[pos].r,x);
}
int a[N];
int main()
{
while(~scanf("%d",&n))
{
sz=root=0;
memset(tree,0,sizeof(tree));
for(int i=1; i<=n; i++)
scanf("%d",&a[i]);
int sum=a[1];
pushin(root,a[1]);
for(int i=2;i<=n;i++)
{
ans1=2*inf;
ans=2*inf;
query(root,a[i]);
query1(root,a[i]);
if(ans1==2*inf)
sum+=abs(a[i]-ans);
else if(ans==2*inf)
sum+=abs(a[i]-ans1);
else
sum+=min(abs(a[i]-ans1),abs(a[i]-ans));
pushin(root,a[i]);
}
printf("%d\n",sum);
}
return 0;
}