QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#118209 | #6627. Line Town | xtqqwq# | 7 | 253ms | 60276kb | C++14 | 4.7kb | 2023-07-03 10:55:02 | 2024-05-31 18:50:39 |
Judging History
answer
#include<bits/stdc++.h>
#define pb push_back
#define fi first
#define se second
#define mp make_pair
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int,int> pii;
typedef pair<ll,ll> pll;
typedef long double ld;
template <typename T> bool chkmin(T &x,T y){return x>y?x=y,1:0;}
template <typename T> bool chkmax(T &x,T y){return x<y?x=y,1:0;}
int readint(){
int x=0,f=1; char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x*f;
}
int n,m;
int a[500005],p[500005],val[500005];
ll sum[500005],sum2[500005],d[500005][2];
vector<int> vec[500005][2];
void add(int x,int c){
for(;x<=n;x+=(x&(-x))) val[x]+=c;
}
int ask(int x){
int ret=0;
for(;x;x-=(x&(-x))) ret+=val[x];
return ret;
}
int main(){
n=readint();
for(int i=1;i<=n;i++) a[i]=readint();
for(int i=1;i<=n;i++) if(i&1) a[i]*=-1;
// for(int i=1;i<=n;i++) cout<<a[i]<<' ';
// cout<<endl;
for(int i=1;i<=n;i++) if(a[i]!=0) p[++m]=abs(a[i]);
sort(p+1,p+m+1);
m=unique(p+1,p+m+1)-p-1;
for(int i=1;i<=n;i++) if(a[i]!=0) a[i]=(lower_bound(p+1,p+m+1,abs(a[i]))-p)*(a[i]<0?-1:1);
for(int i=1;i<=n;i++) if(a[i]!=0) vec[abs(a[i])][a[i]>0].pb(i);
for(int i=1;i<=n;i++) add(i,1);
d[m+1][1]=0,d[m+1][0]=1ll<<60;
for(int i=1;i<=m;i++) d[i][0]=d[i][1]=1ll<<60;
int num=n,all=n;
for(int i=m;i>=1;i--){
for(auto r:vec[i][0]) add(r,-1),all--;
for(auto r:vec[i][1]) add(r,-1),all--;
for(int st=0;st<2;st++){
int ed=st^(num&1)^1;
// cout<<"########## "<<i<<' '<<st<<' '<<ed<<endl;
int tmp=vec[i][1].size()-vec[i][0].size();
int t1=st==1?1:-1;
int t2=ed==0?1:-1;
if(tmp>max(t1,0)+max(t2,0)) continue;
if(tmp<min(t1,0)+min(t2,0)) continue;
ll mina[2]={1ll<<60,1ll<<60}; int cho[2]={0,0};
for(int j=-1;j<=1;j++){
int k=tmp-j;
if(abs(k)>1) continue;
if(abs(j-t1)>1) continue;
if(abs(k-t2)>1) continue;
int pl0=0,pl1=0,tmp=0,up0=vec[i][0].size(),up1=vec[i][1].size();
ll total=0;
// for(int t=0;t<max(vec[i][0].size(),vec[i][1].size());t++) sum[t]=sum2[t]=0;
if(j==1) total+=ask(vec[i][1][0]),pl1++;
else if(j==-1) total+=ask(vec[i][0][0]),pl0++;
if(k==1) total+=all-ask(vec[i][1].back()),up1--;
else if(k==-1) total+=all-ask(vec[i][0].back()),up0--;
// int tpl0=pl0,tpl1=pl1;
// for(int t=pl0;t<up0;t++){
// while(tpl0<up0&&vec[i][0][tpl0]<vec[i][1][t]) tpl0++;
// while(tpl1<up1&&vec[i][1][tpl1]<vec[i][0][t]) tpl1++;
// ll cost=ask(vec[i][0][t])+ask(vec[i][1][t]);
// if((vec[i][0][t]<vec[i][1][t])!=(st^(j!=0))) cost++;
// if(k!=0){
// if(k==1&&vec[i][1].back()<vec[i][0][t]) cost++;
// if(k==-1&&vec[i][0].back()<vec[i][1][t]) cost++;
// }
// sum[t]+=cost;
// if(vec[i][0][t]<vec[i][1][t]){
// // every t+1~tpl0-1>mid cost++
// // mid>=t
// // mid=t: tpl0-t-1;
// // mid=t+1: tpl0-t-2
// // ...
// // mid=tpl0-1: 0
// sum[t]+=tpl0-t-1;
// sum2[t+1]--;
// sum2[tpl0]++;
// }
// else{
// // every t+1~tpl1-1 > mid cost++
// sum[t]+=tpl1-t-1;
// sum2[t+1]--;
// sum2[tpl1]++;
// }
// cost=all-ask(vec[i][0][t])+all-ask(vec[i][1][t]);
// if((vec[i][0][t]>vec[i][1][t])!=(ed^(k!=0))) cost++;
// if(j!=0){
// if(j==1&&vec[i][1][0]>vec[i][0][t]) cost++;
// if(j==-1&&vec[i][0][0]>vec[i][1][t]) cost++;
// }
// // cout<<"cost "<<cost<<endl;
// sum[t]-=cost;
// total+=cost;
// if(vec[i][0][t]<vec[i][1][t]){
// // every tpl1~t-1 <= mid cost++
// // mid < t
// // mid=t-1: t-tpl1
// // mid=t-2: t-tpl1-1
// // mid=tpl1: 1
// sum2[tpl1]++;
// sum2[t]--;
// }
// else{
// // every tpl0~t-1 <=mid cost++
// sum2[tpl0]++;
// sum2[t]--;
// }
// }
// for(int t=pl0+1;t<up0;t++) sum2[t]+=sum2[t-1];
// for(int t=pl0;t<up0;t++) sum[t]+=sum2[t];
// for(int t=pl0+1;t<up0;t++) sum[t]+=sum[t-1];
chkmin(mina[j!=0],total);
// for(int t=pl0;t<up0;t++) if(chkmin(mina,sum[t]+total)) cho=j;
// cout<<"test "<<i<<' '<<j<<' '<<mina<<endl;
// cout<<total<<' ';
// for(int t=pl0;t<up0;t++) cout<<sum[t]+total<<' ';
// cout<<endl;
}
// cout<<"??? "<<st<<' '<<mina[0]<<' '<<mina[1]<<endl;
for(int j=0;j<2;j++) chkmin(d[i][st^j],d[i+1][st]+mina[j]);
}
num-=vec[i][0].size()+vec[i][1].size();
// cout<<"test "<<i<<' '<<d[i][0]<<' '<<d[i][1]<<endl;
}
if(min(d[1][0],d[1][1])>=(1ll<<60)) printf("-1\n");
else printf("%lld\n",min(d[1][0],d[1][1]));
return 0;
}
詳細信息
Subtask #1:
score: 0
Wrong Answer
Test #1:
score: 3
Accepted
time: 0ms
memory: 34768kb
input:
10 1 1 1 1 1 -1 -1 -1 1 -1
output:
-1
result:
ok 1 number(s): "-1"
Test #2:
score: -3
Wrong Answer
time: 6ms
memory: 32464kb
input:
10 1 1 1 1 1 1 -1 1 1 -1
output:
0
result:
wrong answer 1st numbers differ - expected: '3', found: '0'
Subtask #2:
score: 0
Skipped
Dependency #1:
0%
Subtask #3:
score: 0
Skipped
Dependency #1:
0%
Subtask #4:
score: 0
Skipped
Dependency #1:
0%
Subtask #5:
score: 4
Accepted
Test #60:
score: 4
Accepted
time: 9ms
memory: 33700kb
input:
10 3 10 5 -9 7 2 -6 1 8 0
output:
-1
result:
ok 1 number(s): "-1"
Test #61:
score: 0
Accepted
time: 4ms
memory: 32456kb
input:
10 -9 0 -1 7 5 10 6 3 2 -8
output:
13
result:
ok 1 number(s): "13"
Test #62:
score: 0
Accepted
time: 4ms
memory: 34948kb
input:
2000 40667 -598150 -1084780 1201651 1570514 -1859539 -2029075 2941581 -2945945 3038404 3447919 5293872 -5335692 -5669647 5973784 6041345 6346915 -7222112 8820986 -9153143 9563103 9749206 -9894732 -11847193 11987150 12161864 13336572 13528051 -13722732 -13836176 -15497141 -15841563 15862227 16618123 ...
output:
-1
result:
ok 1 number(s): "-1"
Test #63:
score: 0
Accepted
time: 0ms
memory: 35020kb
input:
2000 3038404 -798315545 693574695 172661079 516504064 164016456 193562146 -131746730 382134316 -398886978 188767854 -834289064 -965673210 -826409444 -281381674 450991903 -592752625 81651101 -594873306 -352059270 -651772982 540062674 -769881300 68999588 307151563 -129950325 550154987 354801227 840540...
output:
658039
result:
ok 1 number(s): "658039"
Test #64:
score: 0
Accepted
time: 7ms
memory: 35432kb
input:
2000 -1095 -925 -1049 -1519 951 -1673 -776 345 -38 -1735 -276 -1730 123 -1629 -1896 -1576 -1115 1145 15 797 -948 287 1487 1195 1269 -1240 -1571 -275 -1915 -369 -1221 -1590 -1392 -100 1688 -1287 -241 1130 -1375 -965 669 -147 -307 -795 -1207 1939 120 -305 -915 -1078 -1448 1458 -603 1935 658 774 1471 7...
output:
668545
result:
ok 1 number(s): "668545"
Test #65:
score: 0
Accepted
time: 0ms
memory: 32672kb
input:
2000 1290 1487 -1947 -255 457 -1202 1313 36 -1511 898 1739 987 1809 -1986 -1015 -1127 -703 -223 179 557 199 349 1099 -259 -1401 -1244 -1116 646 -295 1713 1512 127 -1660 343 -1921 -1326 -549 831 1963 -1743 1655 -698 1792 366 1517 -51 404 -1853 -1295 1652 -130 -1562 -1850 -582 1504 1888 822 -24 1807 9...
output:
663841
result:
ok 1 number(s): "663841"
Test #66:
score: 0
Accepted
time: 5ms
memory: 34952kb
input:
2000 56 -1667 -1636 -671 -1311 348 976 1381 -710 -477 -1301 756 -510 495 -1215 -278 1134 950 59 1739 -33 -839 -862 605 761 827 -1708 -1180 -607 1624 -120 -1198 624 -1237 -1874 1788 1005 -331 1266 -467 -1213 1736 -182 594 775 1209 -832 300 1188 -994 -191 -217 1360 -1907 71 436 1294 -590 913 -747 -629...
output:
667052
result:
ok 1 number(s): "667052"
Test #67:
score: 0
Accepted
time: 0ms
memory: 32644kb
input:
1999 -758656 -113741 -374719 7680 -227905 -201318 -200890 -84484 777096 -167712 -126972 -244117 835074 161027 923025 -224756 973701 36622 -913757 -920737 -976062 461264 147694 -162457 358437 -308202 385370 808271 -523703 -303454 -522131 -664739 -505124 306509 948216 948694 -467953 -768055 769796 486...
output:
675957
result:
ok 1 number(s): "675957"
Test #68:
score: 0
Accepted
time: 4ms
memory: 32244kb
input:
1 0
output:
0
result:
ok 1 number(s): "0"
Test #69:
score: 0
Accepted
time: 3ms
memory: 34252kb
input:
2 1000000000 999999999
output:
-1
result:
ok 1 number(s): "-1"
Test #70:
score: 0
Accepted
time: 5ms
memory: 35188kb
input:
2000 999998002 999998004 999998006 999998008 999998010 999998012 999998014 999998016 999998018 999998020 999998022 999998024 999998026 999998028 999998030 999998032 999998034 999998036 999998038 999998040 999998042 999998044 999998046 999998048 999998050 999998052 999998054 999998056 999998058 99999...
output:
999000
result:
ok 1 number(s): "999000"
Test #71:
score: 0
Accepted
time: 10ms
memory: 34324kb
input:
1999 -1000000000 -999012346 -998024692 -997037038 -996049384 -995061730 -994074076 -993086422 -992098768 -991111114 -990123460 -989135806 -988148152 -987160498 -986172844 -985185190 -984197536 -983209882 -982222228 -981234574 -980246920 -979259266 -978271612 -977283958 -976296304 -975308650 -9743209...
output:
0
result:
ok 1 number(s): "0"
Test #72:
score: 0
Accepted
time: 0ms
memory: 35004kb
input:
1999 1998 1997 1996 1995 1994 1993 1992 1991 1990 1989 1988 1987 1986 1985 1984 1983 1982 1981 1980 1979 1978 1977 1976 1975 1974 1973 1972 1971 1970 1969 1968 1967 1966 1965 1964 1963 1962 1961 1960 1959 1958 1957 1956 1955 1954 1953 1952 1951 1950 1949 1948 1947 1946 1945 1944 1943 1942 1941 1940 ...
output:
1998
result:
ok 1 number(s): "1998"
Subtask #6:
score: 3
Accepted
Dependency #5:
100%
Accepted
Test #73:
score: 3
Accepted
time: 74ms
memory: 58012kb
input:
500000 -725 2759 -4173 -4473 4578 -5071 -7897 -7991 9738 -12600 17445 -18596 -20105 -21103 22718 26116 -26973 33169 -33830 34895 37480 -41216 -41665 43933 44687 45286 -46096 46958 47293 -50534 50597 -52520 -57079 57680 58680 -62109 63682 -64495 -64608 64674 -64848 -65420 67176 -74442 -76904 -77098 -...
output:
-1
result:
ok 1 number(s): "-1"
Test #74:
score: 0
Accepted
time: 253ms
memory: 58224kb
input:
500000 716212992 819699933 394255912 695521313 788446410 -466519569 476323400 812543029 724100006 -681244028 -306686799 216473950 496416101 636791486 302599115 190055737 -908659874 -407112922 733684038 -282369420 36611820 323272468 -755065727 -735846631 -22777612 905154351 -694170466 -726666701 7098...
output:
41671567967
result:
ok 1 number(s): "41671567967"
Test #75:
score: 0
Accepted
time: 233ms
memory: 58244kb
input:
500000 -207438 355273 -248123 -19764 185461 162549 -188348 52382 490160 -462312 -44831 -465995 -499994 -43101 -250302 46616 -299265 -249140 383722 -165273 213956 256256 -77000 360942 128116 -376727 -496619 100239 -264529 148062 -435402 -1754 -58897 -473213 469221 -155309 112961 -346627 -296763 -4248...
output:
41688628365
result:
ok 1 number(s): "41688628365"
Test #76:
score: 0
Accepted
time: 239ms
memory: 58168kb
input:
500000 446009 -206999 332464 418913 406238 362645 -398832 101718 476481 97209 16149 -32080 210518 98993 151207 150280 -465090 -481536 201273 -421543 126547 307562 390250 -352233 -297858 -139422 239902 347062 209365 -202318 -124062 209464 241668 -132664 323247 -258834 401172 -466622 -482207 197967 -4...
output:
41663196994
result:
ok 1 number(s): "41663196994"
Test #77:
score: 0
Accepted
time: 211ms
memory: 60276kb
input:
500000 326709 73487 -462901 -247992 -233542 51555 -292893 -379042 397932 -114616 482840 43601 -51534 -182229 -90626 8113 -350602 -9122 -113219 439803 177 370081 -374799 62644 -438795 350357 -148565 453075 -124099 15381 73618 75602 -490979 307811 225874 -65426 -87170 -163734 -392827 436432 402025 252...
output:
41656112780
result:
ok 1 number(s): "41656112780"
Test #78:
score: 0
Accepted
time: 238ms
memory: 58160kb
input:
499999 -6051333 -9732801 3294558 -6403019 -7017102 -9707201 -6061284 -5691041 6049033 8228170 3461230 9448399 5524454 -2197488 -7940006 -1350303 493335 -5456003 1090695 -2008109 -3237925 3617186 6998401 -3574218 999525 -426659 5779982 4786849 5638317 9889583 -6084486 -9252364 -5377778 8297232 545487...
output:
41726273087
result:
ok 1 number(s): "41726273087"
Test #79:
score: 0
Accepted
time: 4ms
memory: 33436kb
input:
1 1000000000
output:
0
result:
ok 1 number(s): "0"
Test #80:
score: 0
Accepted
time: 0ms
memory: 34012kb
input:
2 0 -1000000000
output:
-1
result:
ok 1 number(s): "-1"
Test #81:
score: 0
Accepted
time: 103ms
memory: 58236kb
input:
500000 999500002 999500004 999500006 999500008 999500010 999500012 999500014 999500016 999500018 999500020 999500022 999500024 999500026 999500028 999500030 999500032 999500034 999500036 999500038 999500040 999500042 999500044 999500046 999500048 999500050 999500052 999500054 999500056 999500058 999...
output:
62499750000
result:
ok 1 number(s): "62499750000"
Test #82:
score: 0
Accepted
time: 107ms
memory: 58248kb
input:
499999 -1000000000 -999996544 -999993088 -999989632 -999986176 -999982720 -999979264 -999975808 -999972352 -999968896 -999965440 -999961984 -999958528 -999955072 -999951616 -999948160 -999944704 -999941248 -999937792 -999934336 -999930880 -999927424 -999923968 -999920512 -999917056 -999913600 -99991...
output:
0
result:
ok 1 number(s): "0"
Test #83:
score: 0
Accepted
time: 65ms
memory: 58248kb
input:
499999 499998 499997 499996 499995 499994 499993 499992 499991 499990 499989 499988 499987 499986 499985 499984 499983 499982 499981 499980 499979 499978 499977 499976 499975 499974 499973 499972 499971 499970 499969 499968 499967 499966 499965 499964 499963 499962 499961 499960 499959 499958 499957...
output:
499998
result:
ok 1 number(s): "499998"
Subtask #7:
score: 0
Skipped
Dependency #3:
0%
Subtask #8:
score: 0
Skipped
Dependency #1:
0%