#include using namespace std; using ll=long long; #define int ll #define rng(i,a,b) for(int i=int(a);i=int(a);i--) #define per(i,b) gnr(i,0,b) #define pb push_back #define eb emplace_back #define a first #define b second #define bg begin() #define ed end() #define all(x) x.bg,x.ed #ifdef LOCAL #define dmp(x) cerr<<__LINE__<<" "<<#x<<" "< void chmax(t&a,u b){if(a void chmin(t&a,u b){if(b using vc=vector; template using vvc=vc>; using pi=pair; using vi=vc; template ostream& operator<<(ostream& os,const pair& p){ return os<<"{"< ostream& operator<<(ostream& os,const vc& v){ os<<"{"; for(auto e:v)os< void print_tuple(ostream&,const T&){ } template void print_tuple(ostream&os,const T&t){ if(i)os<<","; os<(t); print_tuple(os,t); } template ostream& operator<<(ostream&os,const tuple&t){ os<<"{"; print_tuple<0,tuple,Args...>(os,t); return os<<"}"; } void print(ll x,int suc=1){ cout<>i; return i; } vi readvi(int n,int off=0){ vi v(n); rep(i,n)v[i]=read()+off; return v; } template void print(const vector&v,int suc=1){ rep(i,v.size()) print(v[i],i==int(v.size())-1?suc:2); } string readString(){ string s; cin>>s; return s; } template T sq(const T& t){ return t*t; } //#define CAPITAL void yes(bool ex=true){ #ifdef CAPITAL cout<<"YES"< void mkuni(vc&v){ sort(all(v)); v.erase(unique(all(v)),v.ed); } ll rand_int(ll l, ll r) { //[l, r] #ifdef LOCAL static mt19937_64 gen; #else static random_device rd; static mt19937_64 gen(rd()); #endif return uniform_int_distribution(l, r)(gen); } int fdiv(int a,int b){ return a/b-((a^b)<0&&a%b); } struct CHT{ struct ln{ int a,b; int eval(int x){return a*x+b;} }; int pos(ln x,ln y){ return fdiv(x.b-y.b,y.a-x.a); } vc ls; //a nonincreasing void add(int a,int b){ if(ls.size()&&ls.back().a==a){ chmin(b,ls.back().b); ls.pop_back(); } int s; while((s=ls.size())>=2){ int x=pos(ls[s-2],ls[s-1]); int y=pos(ls[s-1],ln{a,b}); if(x=2) if(ls[s-2].eval(x)>ls[s-1].eval(x)) break; else ls.pop_back(); return ls.back().eval(x); } }; vi slv(vi a){ int n=a.size(); if(n==1){ return vi{1+a[0]}; } int m=n/2; vi l(m),r(n-m); rep(i,m) l[i]=a[i]; rep(i,n-m) r[i]=a[i+m]; vi x=slv(l),y=slv(r); rep(k,2){ CHT cht; { int s=accumulate(all(l),int(0)); rep(i,m+1){ cht.add(-2*i,s+i*i); if(i>n; vi a=readvi(n); vi ans=slv(a); for(auto v:ans) print(v); }