QOJ.ac
QOJ
ID | Problem | Submitter | Result | Time | Memory | Language | File size | Submit time | Judge time |
---|---|---|---|---|---|---|---|---|---|
#40907 | #3998. The Profiteer | The_Nobody | WA | 475ms | 17428kb | C++ | 2.9kb | 2022-07-27 10:37:46 | 2022-07-27 10:37:48 |
Judging History
answer
#include<bits/stdc++.h>
#define ll long long
#define Il inline
#define mem(u,v) memset(u,v,sizeof(u))
#define rep(i,a,b) for(int i=(a),KKK##i=(b);i<=KKK##i;i++)
#define drep(i,a,b) for(int i=(a),KKK##i=(b);i>=KKK##i;i--)
#define go(u) for(int i=head[u],v=e[i].to;i;i=e[i].nxt,v=e[i].to)
#define writesp(x) write(x),putchar(' ')
#define writeln(x) write(x),puts("")
//#define getchar nc
inline char nc(){static char buf[1000000],*p1=buf,*p2=buf;return p1==p2&&(p2=(p1=buf)+fread(buf,1,1000000,stdin),p1==p2)?EOF:*p1++;}
using namespace std;
Il ll read(){ll sum=0,f=0;char ch=getchar();for(;!isdigit(ch);ch=getchar())f|=(ch=='-');for(;isdigit(ch);ch=getchar())sum=((sum<<1)+(sum<<3)+(ch^48));return f?-sum:sum;}
void write(const ll x){if(x<0){putchar('-');write(-x);return;}if(x>9)write(x/10);putchar(x%10+'0');}
char getc(){char ch=getchar();while(!isalpha(ch))ch=getchar();return ch;}
#define N 20000200
ll n,k,E,ans[N],f[N],top,ha,a[N],b[N],v[N],ANS,T;
struct node{ll i,k,t;}s[N];
bool chk(){
ll sum=0;
rep(i,1,k)sum+=f[i];
// cout<<sum<<endl;
return sum<=k*E;
}
void fix(){
rep(i,1,T)printf(" ");
}
void add(ll c,ll v){
// fix();cout<<"ADD"<<c<<' '<<v<<endl;
top++;
drep(j,k,c)if(f[j]<f[j-c]+v)s[++ha]=(node){j,f[j],top},f[j]=f[j-c]+v;
// fix();rep(i,1,k)cout<<f[i]<<' ';puts("");
}
void re(){
while(s[ha].t==top){
f[s[ha].i]=s[ha].k;
ha--;
}
top--;
// fix();cout<<"DEL"<<endl;
// fix();rep(i,1,k)cout<<f[i]<<' ';puts("");
}
void solve(ll l,ll r,ll x,ll y){
if(l>r||x>y)return;
// cout<<"SOL"<<l<<' '<<r<<' '<<x<<' '<<y<<endl;
if(x==y){
rep(i,l,r)ans[i]=x;
// cout<<"DONE"<<l<<' '<<r<<' '<<x<<endl;
// rep(i,1,k)cout<<f[i]<<' ';puts("");
return;
}
ll mid=(l+r+1)>>1;
rep(i,mid,min(r,x-1))add(b[i],v[i]);
rep(i,l,mid-1)add(a[i],v[i]);
// fix();cout<<"> ERF"<<' '<<mid<<endl;
ll L=max(mid,x),R=y;
while(L<R){
ll MID=(L+R)>>1;
// cout<<"> "<<L<<' '<<R<<endl;
rep(i,L,MID)add(b[i],v[i]);
rep(i,MID+1,R)add(a[i],v[i]);
bool tmp=chk();
// fix();cout<<"> "<<MID<<' '<<tmp<<endl;
rep(i,L,R)re();
if(tmp){
rep(i,MID+1,R)add(a[i],v[i]);
R=MID;
}
else{
rep(i,L,MID)add(b[i],v[i]);
L=MID+1;
}
}
// fix();cout<<"> GET"<<mid<<' '<<L<<endl;
ans[mid]=L;
rep(i,1,y-max(x,mid))re();
// rep(i,1,min(r,x)-l+1)re();
rep(i,l,mid-1)re();
rep(i,L+1,y)add(a[i],v[i]);
T++;
solve(l,mid-1,x,L);
T--;
rep(i,1,y-L)re();
rep(i,mid,min(r,x-1))re();
rep(i,l,min(mid,L-1))add(a[i],v[i]);
// rep(i,l,min(mid,L))if(!T)cout<<"ADDA"<<i<<endl;
rep(i,max(r+1,x),L-1)add(b[i],v[i]);
// rep(i,max(r,x),y)if(!T)cout<<"ADDB"<<i<<endl;
T++;
solve(mid+1,r,L,y);
T--;
rep(i,max(r+1,x),L-1)re();
rep(i,l,min(mid,L-1))re();
}
int main(){
n=read(),k=read(),E=read();
rep(i,1,n)v[i]=read(),a[i]=read(),b[i]=read();
solve(1,n,1,n+1);
// rep(i,1,n)cout<<ans[i]<<" ";puts("");
rep(i,1,n)ANS+=n-ans[i]+1;
writeln(ANS);
}
Details
Tip: Click on the bar to expand more detailed information
Test #1:
score: 100
Accepted
time: 0ms
memory: 3540kb
input:
4 5 3 3 2 4 1 2 3 2 1 2 3 1 3
output:
1
result:
ok single line: '1'
Test #2:
score: 0
Accepted
time: 2ms
memory: 3672kb
input:
4 5 4 3 2 4 1 2 3 2 1 2 3 1 3
output:
3
result:
ok single line: '3'
Test #3:
score: 0
Accepted
time: 2ms
memory: 3748kb
input:
4 5 5 3 2 4 1 2 3 2 1 2 3 1 3
output:
7
result:
ok single line: '7'
Test #4:
score: 0
Accepted
time: 434ms
memory: 10068kb
input:
200000 50 23333 2620 5 21 8192 17 34 6713 38 46 6687 13 42 390 9 13 4192 7 37 7898 17 21 1471 16 45 3579 22 40 9628 8 23 7164 28 45 3669 14 31 5549 29 35 4670 30 39 5811 15 20 4162 18 29 7590 29 41 7786 23 35 383 9 40 5576 39 46 5586 4 9 1110 14 33 8568 4 6 8548 39 42 9133 10 42 6679 22 39 8353 33 3...
output:
0
result:
ok single line: '0'
Test #5:
score: 0
Accepted
time: 444ms
memory: 9952kb
input:
200000 50 233332 8019 18 20 3111 27 40 2015 16 47 6491 17 18 1224 30 38 428 23 34 7521 4 41 7252 6 33 4121 32 45 4230 18 35 1605 21 42 9489 17 25 3704 35 45 6202 8 22 6493 1 5 3041 14 46 4509 23 43 9646 11 48 5294 19 27 3562 19 40 9408 30 47 1751 21 29 4053 4 27 5596 32 49 8609 13 29 1686 4 31 3588 ...
output:
17523021
result:
ok single line: '17523021'
Test #6:
score: 0
Accepted
time: 422ms
memory: 10008kb
input:
200000 50 2333331 7420 30 44 8652 22 28 5418 8 21 9825 3 8 4257 21 40 9962 6 16 3370 18 41 2192 37 41 231 8 18 7764 3 41 3455 9 18 1159 8 46 9775 9 42 4400 21 43 4593 10 22 712 7 22 2067 21 27 9618 9 35 8008 13 38 114 4 31 4503 39 49 4661 14 41 4837 15 35 1371 12 16 9568 21 48 8934 16 34 870 4 35 83...
output:
20000100000
result:
ok single line: '20000100000'
Test #7:
score: 0
Accepted
time: 475ms
memory: 10092kb
input:
200000 50 253330 4837 37 46 2436 11 48 2043 24 50 3544 27 40 1499 21 43 9009 36 46 9172 11 17 585 29 44 6379 4 28 6630 25 37 9230 24 35 5736 23 50 4324 34 50 4624 23 47 9933 3 12 577 12 18 4411 24 32 8750 42 48 4808 21 34 3904 7 17 5979 41 48 2838 29 40 8682 25 46 4026 11 19 8371 8 42 4550 6 24 1546...
output:
2513593675
result:
ok single line: '2513593675'
Test #8:
score: 0
Accepted
time: 434ms
memory: 10052kb
input:
200000 50 193334 8521 14 21 3902 5 6 2949 4 41 1034 10 36 6156 16 36 9432 35 37 3752 25 37 9668 5 9 3194 43 45 9849 1 26 1582 6 10 9920 20 50 994 34 50 9510 12 38 4513 18 31 6294 3 48 4949 9 18 2348 10 49 5492 19 46 2265 3 37 67 20 40 8752 1 5 4610 27 41 7344 27 39 7767 16 29 921 7 16 1853 23 44 936...
output:
1432887
result:
ok single line: '1432887'
Test #9:
score: 0
Accepted
time: 322ms
memory: 7368kb
input:
100000 100 304560 2347 27 64 3715 15 62 6005 16 86 9856 21 55 1347 5 89 9403 25 33 3889 36 74 554 18 95 5218 27 72 3282 2 68 4955 48 83 3478 7 36 3917 34 99 2117 24 41 9764 35 52 7991 81 94 8026 55 69 7755 27 44 3568 18 50 1968 36 57 7992 63 67 7760 4 55 6938 4 53 722 89 99 1111 47 66 5995 71 80 510...
output:
6114559
result:
ok single line: '6114559'
Test #10:
score: 0
Accepted
time: 331ms
memory: 7312kb
input:
100000 100 404561 3114 87 96 4983 68 99 4734 9 65 3721 49 79 7965 40 74 4463 33 81 731 7 61 9048 36 50 6891 40 68 4236 2 43 5436 6 45 1643 64 85 6889 5 95 5673 21 42 2119 57 70 2940 14 98 5620 59 67 8567 76 90 7543 81 99 5576 4 51 7281 4 100 2485 55 75 9357 6 45 4345 33 62 2261 7 26 2371 4 44 9758 5...
output:
29508633
result:
ok single line: '29508633'
Test #11:
score: 0
Accepted
time: 334ms
memory: 7400kb
input:
100000 100 454562 4294 4 37 7975 12 19 4648 1 83 674 41 84 8184 33 57 9088 56 79 2734 56 60 411 11 52 267 20 41 3503 75 86 6921 24 90 1255 49 90 1841 25 27 7767 86 97 9921 25 26 3063 23 44 9237 10 32 4991 7 87 969 36 100 5989 21 87 1420 45 73 780 7 26 6408 85 90 33 31 41 9767 36 89 7666 16 35 3725 1...
output:
160913569
result:
ok single line: '160913569'
Test #12:
score: 0
Accepted
time: 290ms
memory: 6668kb
input:
50000 200 604563 7628 31 102 3694 47 127 4931 101 187 332 7 146 800 131 143 6750 50 136 3718 88 108 5113 36 188 6565 16 49 7739 66 159 215 97 125 1184 90 150 6960 41 173 2281 18 66 3221 144 155 3431 12 162 4191 59 164 8530 28 30 2720 103 196 1176 171 194 2328 124 200 8209 62 114 2606 6 168 1201 120 ...
output:
97043020
result:
ok single line: '97043020'
Test #13:
score: 0
Accepted
time: 329ms
memory: 6820kb
input:
50000 200 804564 2147 132 170 2582 142 185 2492 29 44 4085 50 81 2749 40 115 7068 3 49 5096 72 127 2097 71 122 6697 130 145 6755 141 163 6197 66 130 3397 136 167 7546 71 156 7798 153 169 655 91 94 9498 62 117 7881 71 112 582 67 100 2382 6 189 7366 101 116 2254 56 138 4321 68 125 1601 44 54 2186 65 1...
output:
566251550
result:
ok single line: '566251550'
Test #14:
score: 0
Accepted
time: 339ms
memory: 8356kb
input:
50000 200 824565 2301 142 166 3523 60 153 3438 18 182 4052 42 116 6084 106 166 5687 45 55 2362 34 57 891 171 177 4412 18 49 3142 99 186 9489 86 103 7153 32 90 8357 35 115 6666 161 181 9346 160 196 6328 60 119 3756 16 135 990 130 150 4038 113 128 3608 69 127 8803 119 193 7508 100 141 2918 96 179 5466...
output:
718514472
result:
ok single line: '718514472'
Test #15:
score: 0
Accepted
time: 338ms
memory: 8664kb
input:
50000 200 844566 3943 49 169 1142 177 181 5370 77 91 9254 48 141 1986 87 196 8256 21 188 4440 116 174 6575 5 126 6139 8 67 5192 44 66 3795 51 60 2574 93 139 9861 46 164 3735 46 149 4388 19 46 3578 110 138 6011 25 99 9446 145 189 9215 22 156 9708 119 128 4207 28 172 1229 19 121 4672 161 174 938 35 60...
output:
832753831
result:
ok single line: '832753831'
Test #16:
score: 0
Accepted
time: 275ms
memory: 8344kb
input:
50000 200 864567 1496 192 200 501 22 137 8461 144 151 6841 56 92 4249 5 170 8990 100 155 8686 54 66 3745 144 175 406 127 179 8669 94 108 6146 141 187 1715 178 188 9270 20 160 1541 12 19 9499 66 132 2513 124 152 6228 83 126 8232 106 133 9816 101 197 7403 28 98 4128 14 113 2935 162 190 9541 78 166 773...
output:
1250025000
result:
ok single line: '1250025000'
Test #17:
score: 0
Accepted
time: 266ms
memory: 9004kb
input:
20000 500 604507 8220 251 441 473 267 330 7866 43 172 1675 178 390 7373 216 466 5691 122 274 4101 219 461 7195 406 475 3120 229 462 9594 164 276 8539 4 337 4490 98 498 6378 297 375 2771 40 144 5832 127 372 7877 6 438 9080 140 247 3343 56 354 4402 329 451 7275 56 90 8068 32 47 1412 143 373 9605 17 41...
output:
22551597
result:
ok single line: '22551597'
Test #18:
score: 0
Accepted
time: 279ms
memory: 9224kb
input:
20000 500 704517 6908 150 406 9324 73 113 9557 128 342 3522 265 344 5140 74 283 6988 397 456 8814 436 439 8944 74 400 9177 158 459 6200 105 230 2367 4 247 5138 402 427 9506 181 272 3341 94 396 8436 34 396 3890 195 466 2215 364 372 8343 159 489 7693 57 82 1961 43 74 3854 205 350 5171 38 87 9512 377 4...
output:
46171637
result:
ok single line: '46171637'
Test #19:
score: 0
Accepted
time: 293ms
memory: 9252kb
input:
20000 500 804527 694 70 142 6628 18 245 8865 27 483 472 22 297 5019 332 444 618 411 474 8356 336 483 2233 353 367 3244 193 322 4513 28 455 4447 52 243 7911 8 270 3402 49 469 6244 427 449 7769 27 359 8126 33 108 7584 314 358 6188 115 337 2092 38 154 6307 46 389 7366 34 362 4285 150 393 9307 399 419 6...
output:
90970591
result:
ok single line: '90970591'
Test #20:
score: 0
Accepted
time: 280ms
memory: 11076kb
input:
10000 1000 704537 6257 67 731 8667 640 807 7190 16 344 8470 336 963 5114 32 272 4196 825 946 8056 363 991 7445 616 873 242 237 944 2998 694 786 1256 105 229 3271 538 719 7616 451 687 8292 65 854 6622 407 883 4558 643 805 9402 240 572 1664 182 253 6327 702 851 6549 232 479 3798 22 490 8720 597 963 15...
output:
44558728
result:
ok single line: '44558728'
Test #21:
score: 0
Accepted
time: 248ms
memory: 12720kb
input:
5000 2000 404547 1199 130 149 2031 232 1571 8922 942 1218 7294 143 166 7867 364 666 5214 609 1185 785 618 1453 4296 1165 1731 7467 939 1711 4932 32 336 1804 1377 1750 6492 279 846 3487 361 516 7077 1668 1909 2759 781 1319 1519 574 1831 5072 389 971 7269 521 1155 2308 707 713 1947 288 930 2934 443 76...
output:
3355833
result:
ok single line: '3355833'
Test #22:
score: 0
Accepted
time: 192ms
memory: 13216kb
input:
3000 3000 204557 3644 409 2773 9860 1718 1833 6980 849 1708 5059 744 878 5394 1473 2309 6100 1424 2358 4621 338 2392 8682 781 1500 2734 822 1792 1935 562 1215 6772 454 750 8506 453 1765 3681 1742 2506 6915 387 1496 3963 1943 2004 6263 1859 2591 3124 334 897 3631 352 1380 1132 1075 1753 7719 1832 196...
output:
404256
result:
ok single line: '404256'
Test #23:
score: 0
Accepted
time: 199ms
memory: 13332kb
input:
3000 3000 254557 5040 794 2655 8982 113 2414 2507 796 1594 1127 224 1427 694 655 1184 3136 1607 2269 606 750 1453 7027 696 1263 5853 523 2414 4896 129 2589 7544 878 2295 689 368 1422 5719 1397 1848 3939 835 887 2854 550 738 7426 283 2732 4328 1468 1676 6199 657 1514 8612 1284 1601 6594 288 2356 9930...
output:
626919
result:
ok single line: '626919'
Test #24:
score: 0
Accepted
time: 219ms
memory: 13384kb
input:
3000 3000 304557 9819 663 846 4223 2500 2553 2955 2016 2896 9526 1334 1873 2184 985 1087 1539 1303 2638 6366 2141 2314 8445 329 2572 7882 1503 2075 5998 925 1904 779 1964 2148 2609 774 1142 7463 1613 1986 8926 819 1402 3880 1446 1669 7101 201 1722 8076 273 2570 8653 1484 2658 3424 2201 2591 7281 282...
output:
1789494
result:
ok single line: '1789494'
Test #25:
score: 0
Accepted
time: 223ms
memory: 14216kb
input:
3000 3000 354557 9782 185 1593 3837 2922 2949 8960 518 1539 3903 73 768 3087 2284 2848 4054 239 1071 8856 920 1389 9133 2053 2528 2062 1764 2649 1854 992 2275 6359 205 373 3649 1397 1419 6880 2285 2912 2055 1350 2453 318 1886 1971 4250 829 2565 313 1188 2713 3727 113 2141 3288 627 2569 2197 116 2099...
output:
2198841
result:
ok single line: '2198841'
Test #26:
score: 0
Accepted
time: 259ms
memory: 14248kb
input:
3000 3000 404557 708 802 2784 6640 109 1264 6684 46 1872 2837 1443 2707 587 1190 2330 6780 621 1708 2159 1522 1704 8738 1483 1908 238 137 516 3032 1739 2649 3675 1249 2777 1836 46 1902 1388 1713 2947 5627 476 1478 3073 812 1039 1235 2360 2589 9211 167 2441 8579 1740 2393 1982 461 2914 8369 865 925 8...
output:
3206289
result:
ok single line: '3206289'
Test #27:
score: -100
Wrong Answer
time: 236ms
memory: 17428kb
input:
2000 5000 304567 3784 2499 5000 3491 2864 4941 3594 2101 3768 8110 1158 3663 1039 751 4924 333 80 2728 844 1083 4516 1940 63 3261 4414 1718 2352 4158 1027 3827 7048 1886 3090 7294 2842 3093 9489 1056 4955 5573 3166 4734 737 1959 3819 7890 2266 4309 7453 1680 4291 237 419 486 5602 495 1736 4968 487 4...
output:
1833193
result:
wrong answer 1st lines differ - expected: '1814585', found: '1833193'