QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#864258#9222. Price CombochangziliangAC ✓1983ms212080kbC++207.9kb2025-01-20 12:59:532025-01-20 12:59:55

Judging History

你现在查看的是最新测评结果

  • [2025-01-20 12:59:55]
  • 评测
  • 测评结果:AC
  • 用时:1983ms
  • 内存:212080kb
  • [2025-01-20 12:59:53]
  • 提交

answer

// b, a 的转移都写成矩阵的形式, 这个感觉很厉害 
#include<bits/stdc++.h>
#define pb emplace_back
#define MP make_pair
using namespace std;
typedef long long LL;
const LL INF = 1e18;
const int N = 2e5 + 10;
inline LL Min(LL x, LL y) {return x <= y ? x : y;}
struct matrix {
	LL mat[4][4];
friend matrix operator * (const matrix A, const matrix B) {
		matrix C ;
		C.mat[0][0] = min({A.mat[0][0]+B.mat[0][0],A.mat[0][1]+B.mat[1][0],A.mat[0][2]+B.mat[2][0],A.mat[0][3]+B.mat[3][0]}) ;
		C.mat[0][1] = min({A.mat[0][0]+B.mat[0][1],A.mat[0][1]+B.mat[1][1],A.mat[0][2]+B.mat[2][1],A.mat[0][3]+B.mat[3][1]}) ;
		C.mat[0][2] = min({A.mat[0][0]+B.mat[0][2],A.mat[0][1]+B.mat[1][2],A.mat[0][2]+B.mat[2][2],A.mat[0][3]+B.mat[3][2]}) ;
		C.mat[0][3] = min({A.mat[0][0]+B.mat[0][3],A.mat[0][1]+B.mat[1][3],A.mat[0][2]+B.mat[2][3],A.mat[0][3]+B.mat[3][3]}) ;
		
		C.mat[1][0] = min({A.mat[1][0]+B.mat[0][0],A.mat[1][1]+B.mat[1][0],A.mat[1][2]+B.mat[2][0],A.mat[1][3]+B.mat[3][0]}) ;
		C.mat[1][1] = min({A.mat[1][0]+B.mat[0][1],A.mat[1][1]+B.mat[1][1],A.mat[1][2]+B.mat[2][1],A.mat[1][3]+B.mat[3][1]}) ;
		C.mat[1][2] = min({A.mat[1][0]+B.mat[0][2],A.mat[1][1]+B.mat[1][2],A.mat[1][2]+B.mat[2][2],A.mat[1][3]+B.mat[3][2]}) ;
		C.mat[1][3] = min({A.mat[1][0]+B.mat[0][3],A.mat[1][1]+B.mat[1][3],A.mat[1][2]+B.mat[2][3],A.mat[1][3]+B.mat[3][3]}) ;
		
		C.mat[2][0] = min({A.mat[2][0]+B.mat[0][0],A.mat[2][1]+B.mat[1][0],A.mat[2][2]+B.mat[2][0],A.mat[2][3]+B.mat[3][0]}) ;
		C.mat[2][1] = min({A.mat[2][0]+B.mat[0][1],A.mat[2][1]+B.mat[1][1],A.mat[2][2]+B.mat[2][1],A.mat[2][3]+B.mat[3][1]}) ;
		C.mat[2][2] = min({A.mat[2][0]+B.mat[0][2],A.mat[2][1]+B.mat[1][2],A.mat[2][2]+B.mat[2][2],A.mat[2][3]+B.mat[3][2]}) ;
		C.mat[2][3] = min({A.mat[2][0]+B.mat[0][3],A.mat[2][1]+B.mat[1][3],A.mat[2][2]+B.mat[2][3],A.mat[2][3]+B.mat[3][3]}) ;
		
		C.mat[3][0] = min({A.mat[3][0]+B.mat[0][0],A.mat[3][1]+B.mat[1][0],A.mat[3][2]+B.mat[2][0],A.mat[3][3]+B.mat[3][0]}) ;
		C.mat[3][1] = min({A.mat[3][0]+B.mat[0][1],A.mat[3][1]+B.mat[1][1],A.mat[3][2]+B.mat[2][1],A.mat[3][3]+B.mat[3][1]}) ;
		C.mat[3][2] = min({A.mat[3][0]+B.mat[0][2],A.mat[3][1]+B.mat[1][2],A.mat[3][2]+B.mat[2][2],A.mat[3][3]+B.mat[3][2]}) ;
		C.mat[3][3] = min({A.mat[3][0]+B.mat[0][3],A.mat[3][1]+B.mat[1][3],A.mat[3][2]+B.mat[2][3],A.mat[3][3]+B.mat[3][3]}) ;
		return C ;
	}
  	friend bool operator != (const matrix a, const matrix b) {
  		for(int i = 0; i < 4; i ++ ) 
  		    for(int j = 0; j < 4; j ++ ) 
  		        if(a.mat[i][j] != b.mat[i][j]) return 1;
  		return 0;
	}
} I, T;
typedef pair< int, matrix > PII;
matrix Min(const matrix a, const matrix b) {
	matrix c;
	for(int i = 0; i < 4; i ++ ) 
	    for(int j = 0; j < 4; j ++ ) 
	        c.mat[i][j] = min(a.mat[i][j], b.mat[i][j]);
	return c;
}
struct SegmentTree {
	int l, r; 
	matrix tag, mt, mb; // tag 是懒标记, b 的转移矩阵, a 的可以最后乘 
	#define l(x) t[x].l
	#define r(x) t[x].r
	#define tag(x) t[x].tag
	#define mt(x) t[x].mt
	#define mb(x) t[x].mb
}t[N * 4];
int n, a[N], b[N];
int va[N], vb[N], ta, tb;
int idx[N], up[N]; // 每个上面有多少个 
int cnt[N];
matrix geta(int c, int v) {
	matrix res = T;
    if(c & 1) {
        for(int i = 0; i <= 1; i ++ ) 
        	for(int j = 0; j <= 1; j ++ ) 
        		if(i == 0) res.mat[i * 2 + j][(i ^ 1) * 2 + j] = 1LL * (c + 1) / 2 * v;
        		else res.mat[i * 2 + j][(i ^ 1) * 2 + j] = 1LL * (c - 1) / 2 * v;
	}	
	else {
		for(int i = 0; i < 4; i ++ ) res.mat[i][i] = 1LL * (c / 2) * v;
	}
	return res;
}
matrix getb(int c, int v) {
	matrix res = T;
    if(c & 1) {
        for(int i = 0; i <= 1; i ++ ) 
        	for(int j = 0; j <= 1; j ++ ) 
        		if(j == 0) res.mat[i * 2 + j][i * 2 + (j ^ 1)] = 1LL * (c + 1) / 2 * v;
        		else res.mat[i * 2 + j][i * 2 + (j ^ 1)] = 1LL * (c - 1) / 2 * v;
	}	
	else {
		for(int i = 0; i < 4; i ++ ) res.mat[i][i] = 1LL * (c / 2) * v;
	}
	return res;
}
bool cmp(int x, int y) {
	return (a[x] < a[y]) || (a[x] == a[y] && b[x] > b[y]);
}
void update(int p) {
	mt(p) = Min(mt(p << 1 | 1) * mb(p << 1), mt(p << 1));
	mb(p) = mb(p << 1 | 1) * mb(p << 1);
}
void spread(int p) {
	if(tag(p) != I) {
		mt(p << 1) = mt(p << 1) * tag(p); mt(p << 1 | 1) = mt(p << 1 | 1) * tag(p);
		tag(p << 1) = tag(p << 1) * tag(p); tag(p << 1 | 1) = tag(p << 1 | 1) * tag(p);
		tag(p) = I;
	} 
}
void build(int p, int l, int r) {
	l(p) = l, r(p) = r;
	tag(p) = I, mb(p) = I;
	if(l == r) {
		mt(p) = T;
		return ;
	}
	int mid = (l + r >> 1);
	build(p << 1, l, mid);
	build(p << 1 | 1, mid + 1, r);
	update(p);
}
void ins(int p, int pos, const matrix w) {
	if(l(p) == r(p)) {
		mt(p) = Min(mt(p), w);
		return ;
	}
	spread(p);
	int mid = (l(p) + r(p) >> 1);
	if(pos <= mid) ins(p << 1, pos, w);
	else ins(p << 1 | 1, pos, w);
	update(p);
}
void Change_a(int p, int l, int r, const matrix w) {
	if(!(mt(p) != T)) return ;
	if(l <= l(p) && r >= r(p)) {
		mt(p) = mt(p) * w; 
		tag(p) = tag(p) * w;
		return ;
	}
	spread(p);
	int mid = (l(p) + r(p) >> 1);
	if(l <= mid) Change_a(p << 1, l, r, w);
	if(r > mid) Change_a(p << 1 | 1, l, r, w);
	update(p);
} 
void Change_b(int p, int pos) {
	if(l(p) == r(p)) {
		mb(p) = getb(cnt[pos], vb[pos]);
		return ;
	}
	int mid = (l(p) + r(p) >> 1);
	if(pos <= mid) Change_b(p << 1, pos);
	else Change_b(p << 1 | 1, pos);
	update(p);
}
matrix ret, sb;
void ask(int p, int l, int r) {
	if(l <= l(p) && r >= r(p)) {ret = Min(ret, mt(p) * sb); sb = mb(p) * sb; return ;}
	spread(p);
	int mid = (l(p) + r(p) >> 1);
	if(l <= mid) ask(p << 1, l, r);
	if(r > mid) ask(p << 1 | 1, l, r);
}
matrix Ask_mt(int p, int pos) {
	if(l(p) == r(p)) return mt(p);
	spread(p);
	int mid = (l(p) + r(p) >> 1);
	if(pos <= mid) return Ask_mt(p << 1, pos);
	else return Ask_mt(p << 1 | 1, pos);
}
vector< PII > vec;
int main() {
	scanf("%d", &n);
	for(int i = 0; i <= n + 1; i ++ ) {
		if(i == 0) a[i] = 0;
		else if(i == n + 1) a[i] = 1e9 + 10;
		else scanf("%d", &a[i]);
		va[++ ta] = a[i];
	}
	for(int i = 0; i <= n + 1; i ++ ) {
		if(i == 0) b[i] = 0;
		else if(i == n + 1) b[i] = 1e9 + 10;
		else scanf("%d", &b[i]);
		vb[++ tb] = b[i];
	}
	sort(va + 1, va + ta + 1);
	ta = unique(va + 1, va + ta + 1) - (va + 1);
	sort(vb + 1, vb + tb + 1);
	tb = unique(vb + 1, vb + tb + 1) - (vb + 1);
	for(int i = 0; i <= n + 1; i ++ ) {
		a[i] = lower_bound(va + 1, va + ta + 1, a[i]) - (va);
		b[i] = lower_bound(vb + 1, vb + tb + 1, b[i]) - (vb);
	} // 离散化 
	for(int i = 0; i <= n + 1; i ++ ) idx[i] = i;
	sort(idx, idx + n + 2, cmp);
	for(int i = 0; i <= n + 1; i ++ ) {
		if(a[idx[i]] != a[idx[i - 1]]) up[idx[i]] = 1;
		else up[idx[i]] = up[idx[i - 1]] + 1;
	}
	up[idx[0]] = 0;
	for(int i = 0; i < 4; i ++ ) 
	    for(int j = 0; j < 4; j ++ ) {
	        I.mat[i][j] = (i == j ? 0 : INF);
	    	T.mat[i][j] = INF;
		}
	build(1, 1, tb);
	for(int i = n + 1; i >= 0; i -- ) { // 倒着转移 
	    int o = idx[i]; // 首先可以在这个 b[o] 的下面乘上一个 a 的转移向量 
	    if(a[idx[i]] != a[idx[i + 1]]) { // 换列的时候插入 
	    	for(auto v : vec) {
	    		ins(1, v.first, v.second);
			}
			vec.clear();
		}
		if(i <= n) {
		    Change_a(1, 1, b[o], geta(1, va[a[o]])); // 乘上这样一个矩阵,表示a集合多了一个数
			ret = T; sb = getb(cnt[b[o]], vb[b[o]]); 
			ask(1, b[o] + 1, tb); // 状态 * b 矩阵, 表示这个状态多了若干个 b 矩阵 
			ret = ret * geta(up[o], va[a[o]]);
			vec.pb(MP(b[o], ret));
			cnt[b[o]] ++;
			Change_b(1, b[o]); // 半在线, 改变 b 矩阵 
		}
		else { // 第一个 
			matrix tmp;
			for(int j = 0; j < 4; j ++ ) 
			    for(int k = 0; k < 4; k ++ ) {
			        if(j == 0 && k == 0) tmp.mat[j][k] = 0;
			    	else tmp.mat[j][k] = INF;
				}
            ins(1, b[o], tmp);
		}
	}
	matrix ret = vec[0].second;
	LL res = INF;
	for(int i = 0; i < 4; i ++ ) res = min(res, ret.mat[0][i]);
	printf("%lld\n", res);
	return 0;
}
/*
7
7 9 1 2 15 20 17 
12 14 18 7 4 19 10 

*/

詳細信息

Test #1:

score: 100
Accepted
time: 0ms
memory: 8020kb

input:

7
10 12 19 99 10 8 49
9 14 15 199 11 7 19

output:

131

result:

ok single line: '131'

Test #2:

score: 0
Accepted
time: 0ms
memory: 5964kb

input:

7
10 12 19 99 10 8 49
9 14 15 199 11 7 19

output:

131

result:

ok single line: '131'

Test #3:

score: 0
Accepted
time: 674ms
memory: 10784kb

input:

199913
1212731 2525164 3210261 2457211 1013738 1931420 923123 867112 762069 2108660 108920 2491869 867107 387025 2278045 574027 1661570 820133 1274150 2001346 779766 3305537 3000211 2418643 2108660 2001343 1074820 2754411 826712 3117447 1661569 338161 1849064 3007920 3057426 468078 3252798 1274146 4...

output:

154816494865

result:

ok single line: '154816494865'

Test #4:

score: 0
Accepted
time: 1124ms
memory: 212076kb

input:

200000
97216869 743886950 33071099 93740214 165915739 714765240 770423425 498199793 631193672 753722174 569396548 842251035 911607641 450531347 765200530 739362614 91640365 174209387 248940417 335559443 238573490 479206903 882783448 200485674 717481029 526848873 692757023 616376164 573933118 2566387...

output:

49954742111708

result:

ok single line: '49954742111708'

Test #5:

score: 0
Accepted
time: 163ms
memory: 44804kb

input:

200000
1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000000 1000000...

output:

100000000000000

result:

ok single line: '100000000000000'

Test #6:

score: 0
Accepted
time: 1135ms
memory: 211020kb

input:

200000
274771488 823198191 332419028 866914185 137030479 445861162 505221814 805396419 842179806 540452002 510333908 765762441 345734318 975440944 186438657 676989478 108190396 339715111 337119327 462480232 634226928 438891079 609658471 156142766 16523966 699505629 190085420 960768051 824783291 5029...

output:

49967269431852

result:

ok single line: '49967269431852'

Test #7:

score: 0
Accepted
time: 1969ms
memory: 210172kb

input:

200000
543681210 962563205 250397700 268525543 975554886 624102999 997517472 902158917 972202292 861887640 35775032 260723190 581651070 908449029 920192222 562166727 71415077 442629695 247231608 726904965 155868789 579129175 301712168 760082974 11645034 552993020 532073045 440207656 810726266 150259...

output:

33304730166370

result:

ok single line: '33304730166370'

Test #8:

score: 0
Accepted
time: 1203ms
memory: 210984kb

input:

199998
689913610 725385763 163484638 868994205 449858903 631765674 574347626 260863034 740441133 55535165 612711113 42693300 91469451 459079704 241970526 395707182 581503675 186168355 536621457 878005967 776375657 311683657 643727441 342258990 29883737 50215092 771277858 346123680 93534188 401651778...

output:

49871887186423

result:

ok single line: '49871887186423'

Test #9:

score: 0
Accepted
time: 1155ms
memory: 212000kb

input:

199999
105379362 923915615 215200323 953973925 78641957 232880810 918464290 933150426 311608001 159423490 707314389 967885525 479000867 35207303 644433637 193664828 4262237 382322834 849172685 887758838 699247657 92331957 549213389 480500907 257190920 229226021 152614682 98166290 186656024 866087158...

output:

50074806153680

result:

ok single line: '50074806153680'

Test #10:

score: 0
Accepted
time: 1983ms
memory: 211388kb

input:

199999
657143391 45666910 758637402 727254629 218608391 985079369 439610506 817090643 927202721 486739391 516136382 282109517 220802622 390616397 850701405 967156836 100821917 627827474 93574692 820094865 60293196 308305441 661279124 464897166 824130309 998638602 843728821 402660293 852360018 864579...

output:

33311529559302

result:

ok single line: '33311529559302'

Test #11:

score: 0
Accepted
time: 0ms
memory: 8024kb

input:

1
49
60

output:

49

result:

ok single line: '49'

Test #12:

score: 0
Accepted
time: 1324ms
memory: 110408kb

input:

199911
85073 1612357 1117052 2574297 2436828 222840 2319502 591643 2319425 180085 129090 1754039 1524000 590792 1313199 991385 2882348 2917574 2356578 2376276 1232750 2736131 3254231 1294377 1379116 1164673 1623200 1694383 2319482 2625088 2028684 2640741 1977127 3289737 1144951 2917936 362582 105848...

output:

168896977958

result:

ok single line: '168896977958'

Test #13:

score: 0
Accepted
time: 1137ms
memory: 211652kb

input:

200000
142327150 513430292 906769950 518151702 849238647 155501711 925373625 222087519 417768102 614559622 809144615 727176011 108955247 243279471 691459975 22633211 727045283 931086253 49092450 115601776 667512127 670752015 471332788 474444363 633117334 790426364 431200432 208453449 919605053 13528...

output:

49997566595072

result:

ok single line: '49997566595072'

Test #14:

score: 0
Accepted
time: 1176ms
memory: 211784kb

input:

199997
6999946 194430278 108816897 80696400 310045386 149673615 188623556 419014404 64078835 48842951 223647975 390286195 244417721 261759561 60310580 150670599 14722383 326063 42928058 221116909 161453531 140151053 296965067 247014569 11645014 413924829 172760189 345315367 55227980 280488862 586801...

output:

21025271981534

result:

ok single line: '21025271981534'

Test #15:

score: 0
Accepted
time: 1864ms
memory: 210620kb

input:

200000
793895460 939042903 605004391 428355307 120383808 596587064 693444786 518489765 515441460 212695431 48914267 424096848 829856067 653560354 794365628 657155054 981570419 970104732 677694650 512172466 858817525 359974649 854988411 222801425 262743476 365072406 906324817 928141279 126786652 4513...

output:

21851360103579

result:

ok single line: '21851360103579'

Test #16:

score: 0
Accepted
time: 1926ms
memory: 211524kb

input:

200000
92405740 230051343 94698482 917557300 124131769 361499357 976694091 463559129 258317776 704526053 192033713 338799970 398554963 909096457 56761970 864962722 971953118 495761835 350934210 465936906 524944026 887387114 856399250 359738396 947522411 693550385 904383383 844558602 328780170 752863...

output:

38847359292701

result:

ok single line: '38847359292701'

Test #17:

score: 0
Accepted
time: 0ms
memory: 8008kb

input:

2
7 76
10 89

output:

76

result:

ok single line: '76'

Test #18:

score: 0
Accepted
time: 1960ms
memory: 211088kb

input:

200000
244021017 875612675 432728994 23711122 312320097 383983148 216608030 114030470 402878743 9332136 232199219 423620935 448837640 316651064 385864803 244577888 106045090 721508192 495447244 339623310 379106434 110632630 146087920 119129349 29487037 578664996 657979959 781106267 488587591 3036138...

output:

33330773164506

result:

ok single line: '33330773164506'

Test #19:

score: 0
Accepted
time: 1126ms
memory: 211216kb

input:

200000
445744654 443694652 921312513 486929743 451137133 706037450 579745155 766897701 267962088 355969746 6465340 438890371 465601418 736566159 493336392 973448005 813018735 905271257 137892756 209739569 673165795 305571934 330150126 879561606 620421487 485540368 561206289 698815389 82869758 287991...

output:

50049229605683

result:

ok single line: '50049229605683'

Test #20:

score: 0
Accepted
time: 0ms
memory: 5916kb

input:

2
7 76
89 10

output:

17

result:

ok single line: '17'

Test #21:

score: 0
Accepted
time: 1936ms
memory: 212080kb

input:

199999
793242061 669342146 543588608 882891106 341176229 958125367 784590587 139209586 530371510 715692132 870391324 832904085 565576613 606908811 917421250 711562465 854058638 465241186 478398164 660942120 919175606 477502123 716706138 330975221 141043582 139500841 711510209 904874680 714386666 588...

output:

33348117751480

result:

ok single line: '33348117751480'

Test #22:

score: 0
Accepted
time: 1130ms
memory: 111160kb

input:

199989
89926964 182799389 183179415 120868578 195641603 193430072 119513695 37533839 114610519 133705816 3321649 67400788 199548630 110795787 46034038 99459241 71794114 162441770 61356634 101391579 676001 161319751 1074131 19850785 110548536 43687098 188514776 114550199 36040921 193647232 43232632 1...

output:

10153136627887

result:

ok single line: '10153136627887'

Test #23:

score: 0
Accepted
time: 1184ms
memory: 211916kb

input:

200000
148167 937407 1724322 93836 1212638 561839 459101 1770455 636776 1430291 46270 1538313 71425 858941 479696 455959 1790564 1754423 1643683 1183121 1623556 58960 985460 1213628 492013 1603038 742006 319207 1121661 638507 1544626 1026953 285473 560993 1814313 1252825 358500 1864370 608666 143457...

output:

100188447201

result:

ok single line: '100188447201'

Test #24:

score: 0
Accepted
time: 1714ms
memory: 211204kb

input:

199999
442551444 912392223 324603571 938425264 949530237 18894904 950855761 691012143 106328253 748915991 748343481 221457635 154734228 51263445 302354447 834989226 2082124 173637319 244185082 12789807 54002379 307343711 190690720 378387054 890668393 806027136 958028546 902508699 94632159 889239615 ...

output:

47532009537959

result:

ok single line: '47532009537959'

Test #25:

score: 0
Accepted
time: 1198ms
memory: 209972kb

input:

199982
102522751 30277595 190549652 71219507 197763228 48621002 151446912 202479087 169304461 164438266 179496311 159889010 92336655 59122107 85056193 178336405 29425174 138439101 179568090 162169806 184038655 51992608 78868851 106412878 145527831 80681312 138150653 114472742 153904803 98480569 5935...

output:

10299356204318

result:

ok single line: '10299356204318'

Test #26:

score: 0
Accepted
time: 1131ms
memory: 210880kb

input:

200000
73801034 347281304 283573375 389939508 358430052 90329268 894017257 174336980 332009492 856529136 601932136 880949401 324762153 764777799 110843668 178114056 653340678 654852069 284237074 377794799 991663598 575628958 947879999 72107494 459600466 64341501 65189918 573985855 785047220 81419991...

output:

50121681200274

result:

ok single line: '50121681200274'

Test #27:

score: 0
Accepted
time: 1260ms
memory: 211704kb

input:

199989
113194381 18453124 39197171 98397543 45824456 95978171 103207468 23963206 96708868 91858539 125669636 29727287 45641460 183601442 98544899 149665561 122600831 127873364 56083730 177285601 173773998 98397724 40235628 162198786 129762866 137490430 131427272 1304290 143019726 154547489 153595991...

output:

10202456232461

result:

ok single line: '10202456232461'

Test #28:

score: 0
Accepted
time: 1121ms
memory: 211748kb

input:

199999
960158369 810645963 431764335 710241238 650235958 274350815 97668804 360540767 980928506 256853239 106090204 618131257 272043818 632096020 447638357 406760186 23066426 881025543 315693732 882749165 324384940 265611873 582033714 297534692 137582097 429674820 971965089 388908340 501451208 45700...

output:

50030092692837

result:

ok single line: '50030092692837'

Extra Test:

score: 0
Extra Test Passed