UOJ Logo

NOI.AC

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#197876#2399. 全连snow_trace1002040ms110536kbC++1.9kb2023-11-16 10:16:552023-11-16 12:04:08

answer

#include<bits/stdc++.h>
using namespace std;
#define lowbit(x) x&(-x)
inline int read(){
    char c = getchar();int x = 0;
    while(c<'0' or c>'9')c = getchar();
    while('0'<=c and c<='9')x = x*10+(c^48),c = getchar();
    return x;
}
void
 write(__int128 x){
    if(x>=10)write(x/10);putchar('0'+x%10);
}
/*
struct node{
    int l,r;
    __int128 mx;
    void add(int x){mx = x;}
}tree[4000005];
void build(int l,int r,int k){
    tree[k].l = l,tree[k].r = r;
    if(l+1 == r){
        return;
    }build(l,l+r>>1,k<<1),build(l+r>>1,r,k<<1|1);
}void upd(int k,int pos,int add){
    int l = tree[k].l,r = tree[k].r,mid = l+r>>1;
    if(l+1 == r){
        tree[k].add(add);return;
    }if(pos<mid)upd(k<<1,pos,add);
    else upd(k<<1|1,pos,add);
    tree[k].mx =max(tree[k<<1].mx,tree[k<<1|1].mx);
}int query(int l,int r,int k){
    int ll = tree[k].l,rr = tree[k].r;
    if(l>=rr or ll>=r)return 0;
    if(l<=ll and rr<=r)return tree[k].mx;
    return max(query(l,r,k<<1),query(l,r,k<<1|1));
}*/
int n;
__int128 tree[1000005];
void upd(int pos,__int128 add){
    for(int i = pos;i<=n;i+=lowbit(i))tree[i] = max(tree[i],add);
}__int128 query(int pos){
    __int128 res = 0;
    for(int i =pos;i>0;i-=lowbit(i))res = max(tree[i],res);
    return res;
}
int t[1000005],v[1000005];
vector<int>pos[1000005];
__int128 a[1000005],dp[1000005];
signed main(){
    cin>>n;
    for(int i = 1;i<=n;i++)t[i] = read();
    for(int i = 1;i<=n;i++)v[i] = read();
    dp[0] = 0;
    for(int i =1;i<=n;i++)a[i] = (__int128)v[i]*t[i];
    for(int i = 1;i<=n;i++)if(i+t[i]<=n)pos[i+t[i]].push_back(i);
    for(int i = 1;i<=n;i++){
    //	cout << i << endl;
        for(int j = 0;j<pos[i].size();j++)upd(pos[i][j],dp[pos[i][j]]);
        dp[i] = a[i]+query(i-t[i]);
    }__int128 res = 0;
    for(int i = 1;i<=n;i++)res = max(res,dp[i]);
    write(res);
    return 0;
}

详细

小提示:点击横条可展开更详细的信息

Test #1:

score: 5
Accepted
time: 0ms
memory: 24664kb

input:

5
5 3 5 5 1
480208416 560202151 230193932 182093570 999846296

output:

2680452749

result:

ok single line: '2680452749'

Test #2:

score: 5
Accepted
time: 3ms
memory: 24672kb

input:

10
3 2 9 3 4 1 4 7 1 8
32905395 72720216 54089340 289875333 847413895 598817637 206111130 144722879 ...

output:

4191763507

result:

ok single line: '4191763507'

Test #3:

score: 5
Accepted
time: 3ms
memory: 24672kb

input:

15
9 2 13 7 2 4 10 4 2 3 3 1 2 2 2
860947809 695835339 13996045 709112244 119816376 441006970 575090...

output:

10490468135

result:

ok single line: '10490468135'

Test #4:

score: 5
Accepted
time: 4ms
memory: 24672kb

input:

20
2 10 15 4 7 1 2 2 7 3 17 6 4 4 5 4 4 4 2 1
457301510 838843149 408120703 43551970 387080784 10169...

output:

11883246598

result:

ok single line: '11883246598'

Test #5:

score: 5
Accepted
time: 8ms
memory: 24748kb

input:

1000
103 2 2 13 4 5 183 175 29 1 675 1 199 195 1 8 7 19 1 945 4 6 574 8 1 13 2 16 2 40 175 33 2 3 35...

output:

1162897804752

result:

ok single line: '1162897804752'

Test #6:

score: 5
Accepted
time: 8ms
memory: 24820kb

input:

2000
1252 2 2 3 189 1847 22 114 7 48 15 157 1160 1419 10 31 76 114 2 369 2 5 1 460 63 1 8 1130 63 17...

output:

2771903520915

result:

ok single line: '2771903520915'

Test #7:

score: 5
Accepted
time: 16ms
memory: 25028kb

input:

5000
4842 6 3352 7 318 163 170 1 4325 378 15 2 1289 1 2 7 946 12 1945 1 9 9 255 4 4543 8 3006 28 2 3...

output:

7861941062084

result:

ok single line: '7861941062084'

Test #8:

score: 5
Accepted
time: 8ms
memory: 25400kb

input:

10000
87 8310 1 21 9174 12 1524 1 1 457 1 1380 9929 121 2 3846 4 4 41 6282 9 8 445 807 362 32 8986 8...

output:

17334962387424

result:

ok single line: '17334962387424'

Test #9:

score: 5
Accepted
time: 16ms
memory: 26872kb

input:

30000
79 110 19001 3892 137 20285 2 104 167 12458 29 12 1 7544 35 18127 147 21 2712 29763 868 24597 ...

output:

51316652640940

result:

ok single line: '51316652640940'

Test #10:

score: 5
Accepted
time: 18ms
memory: 28336kb

input:

50000
1547 1187 141 27 15818 12251 7271 29 2 8 13 2 3818 398 8167 17161 14 16962 6760 540 8784 7 240...

output:

88026787637620

result:

ok single line: '88026787637620'

Test #11:

score: 5
Accepted
time: 34ms
memory: 31996kb

input:

100000
9736 5862 1 2099 11612 21 24021 14624 446 396 81 2 1899 49526 781 69432 7 10177 1320 124 471 ...

output:

180410914037070

result:

ok single line: '180410914037070'

Test #12:

score: 5
Accepted
time: 57ms
memory: 39336kb

input:

200000
1412 5 2 13253 1 1 1 185647 47 1 507 150635 376 7 74 47462 53 4 5411 3 5154 130 19 265 8 185 ...

output:

376348758470573

result:

ok single line: '376348758470573'

Test #13:

score: 5
Accepted
time: 195ms
memory: 61464kb

input:

500000
383 119 2 1429 1026 29 301750 117 28940 26 375666 2347 249 62156 74903 8 22 2670 430211 140 3...

output:

959624672322043

result:

ok single line: '959624672322043'

Test #14:

score: 5
Accepted
time: 304ms
memory: 83432kb

input:

800000
886 1 403044 156168 25247 19 6686 1935 1483 338 2 7 26 6 84 62996 2 1 4 21109 41190 9828 7294...

output:

1542878834606328

result:

ok single line: '1542878834606328'

Test #15:

score: 5
Accepted
time: 410ms
memory: 98260kb

input:

1000000
237 426 2208 4 36156 454152 1 48361 76425 46521 3 684890 41403 32 274 7077 53 20 6 4 191644 ...

output:

1908394076801355

result:

ok single line: '1908394076801355'

Test #16:

score: 5
Accepted
time: 408ms
memory: 98252kb

input:

1000000
60 188620 109 225192 99984 137997 442 75 6451 26437 72089 45937 92 2011 49603 10 613 30841 7...

output:

1915598573008513

result:

ok single line: '1915598573008513'

Test #17:

score: 5
Accepted
time: 28ms
memory: 33236kb

input:

100000
314 314 314 314 314 314 314 314 314 314 314 314 314 314 314 314 314 314 314 314 314 314 314 3...

output:

94625535409026

result:

ok single line: '94625535409026'

Test #18:

score: 5
Accepted
time: 21ms
memory: 33160kb

input:

100000
2050 2050 2050 2050 2050 2050 2050 2050 2050 2050 2050 2050 2050 2050 2050 2050 2050 2050 205...

output:

99469079815450

result:

ok single line: '99469079815450'

Test #19:

score: 5
Accepted
time: 243ms
memory: 110536kb

input:

1000000
1003 1003 1003 1003 1003 1003 1003 1003 1003 1003 1003 1003 1003 1003 1003 1003 1003 1003 10...

output:

969470905350325

result:

ok single line: '969470905350325'

Test #20:

score: 5
Accepted
time: 256ms
memory: 109888kb

input:

1000000
15023 15023 15023 15023 15023 15023 15023 15023 15023 15023 15023 15023 15023 15023 15023 15...

output:

1003927881833136

result:

ok single line: '1003927881833136'

Extra Test:

score: 0
Extra Test Passed