QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#642755#5165. 比赛KiharaTouma60 1433ms82400kbC++144.9kb2024-10-15 16:09:542024-10-15 16:09:54

Judging History

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

  • [2024-10-15 16:09:54]
  • 评测
  • 测评结果:60
  • 用时:1433ms
  • 内存:82400kb
  • [2024-10-15 16:09:54]
  • 提交

answer

//qoj5165
#include <bits/stdc++.h>
using namespace std;

const int N = 2.5e5 + 10;
int T, n, Q, sa[N], sb[N];
typedef unsigned long long ll;
ll a[N], b[N], ans[N];
vector<pair<int, int> > q[N];

struct mat{
    ll a[5][5];
    mat operator * (const mat &b) const {
        mat c;
        for(int i = 0; i < 5; ++ i){
            for(int j = 0; j < 5; ++ j){
                c.a[i][j] = a[i][0] * b.a[0][j]
                          + a[i][1] * b.a[1][j]
                          + a[i][2] * b.a[2][j]
                          + a[i][3] * b.a[3][j]
                          + a[i][4] * b.a[4][j];
            }
        }
        return c;
    }
} ini;
mat ma(ll x){
    mat k = ini;
    k.a[1][2] = k.a[4][0] = x;
    return k;
}
mat mb(ll x){
    mat k = ini;
    k.a[0][2] = k.a[4][1] = x;
    return k;
}
mat lsh(){
    mat k = ini;
    k.a[2][3] = 1;
    return k;
}
struct node{
    ll x, y, xy, all, cnt;
    mat tag;
    void mdf(mat val){
        // for(int i = 0; i < 5; ++ i){
        //     for(int j = 0; j < 5; ++ j){
        //         printf("%llu ", val.a[i][j]);
        //     }
        //     puts("");
        // }
        // printf("%llu %llu %llu %llu %llu\n", x, y, xy, all, cnt);
        ll tx = x, ty = y, txy = xy, tall = all, tcnt = cnt;
        x = tx * val.a[0][0] + ty * val.a[1][0] + txy * val.a[2][0] + tall * val.a[3][0] + tcnt * val.a[4][0];
        y = tx * val.a[0][1] + ty * val.a[1][1] + txy * val.a[2][1] + tall * val.a[3][1] + tcnt * val.a[4][1];
        xy = tx * val.a[0][2] + ty * val.a[1][2] + txy * val.a[2][2] + tall * val.a[3][2] + tcnt * val.a[4][2];
        all = tx * val.a[0][3] + ty * val.a[1][3] + txy * val.a[2][3] + tall * val.a[3][3] + tcnt * val.a[4][3];
        cnt = tx * val.a[0][4] + ty * val.a[1][4] + txy * val.a[2][4] + tall * val.a[3][4] + tcnt * val.a[4][4];
        // printf("%llu %llu %llu %llu %llu\n", x, y, xy, all, cnt);
    }
} t[N*4];
void psd(int p){
    t[p<<1].mdf(t[p].tag);
    t[p<<1|1].mdf(t[p].tag);
    t[p<<1].tag = t[p<<1].tag * t[p].tag;
    t[p<<1|1].tag = t[p<<1|1].tag * t[p].tag;
    for(int i = 0; i < 5; ++ i){
        for(int j = 0; j < 5; ++ j){
            t[p].tag.a[i][j] = (i == j);
        }
    }
}
void upd(int p){
    t[p].x = t[p<<1].x + t[p<<1|1].x;
    t[p].y = t[p<<1].y + t[p<<1|1].y;
    t[p].xy = t[p<<1].xy + t[p<<1|1].xy;
    t[p].all = t[p<<1].all + t[p<<1|1].all;
    t[p].cnt = t[p<<1].cnt + t[p<<1|1].cnt;
}
void build(int p, int l, int r){
    t[p].cnt = r - l + 1;
    for(int i = 0; i < 5; ++ i){
        for(int j = 0; j < 5; ++ j){
            t[p].tag.a[i][j] = (i == j);
        }
    }
    if(l != r){
        int mid = l + r >> 1;
        build(p<<1, l, mid);
        build(p<<1|1, mid+1, r);
        upd(p);
    }
}
void add(int p, int l, int r, int ql, int qr, mat val){
    if(qr < l || r < ql){
        return;
    } else if(ql <= l && r <= qr){
        t[p].mdf(val);
        t[p].tag = t[p].tag * val;
    } else {
        int mid = l + r >> 1;
        psd(p);
        add(p<<1, l, mid, ql, qr, val);
        add(p<<1|1, mid+1, r, ql, qr, val);
        upd(p);
    }
}
ll ask(int p, int l, int r, int ql, int qr){
    if(qr < l || r < ql){
        return 0;
    } else if(ql <= l && r <= qr){
        return t[p].all;
    } else {
        int mid = l + r >> 1;
        psd(p);
        return ask(p<<1, l, mid, ql, qr) + ask(p<<1|1, mid+1, r, ql, qr);
    }
}

int main(){
    ios::sync_with_stdio(false);
    cin.tie(0);
    cout.tie(0);
    cin >> T >> n;
    for(int i = 0; i < 5; ++ i){
        for(int j = 0; j < 5; ++ j){
            ini.a[i][j] = (i == j);
        }
    }
    for(int i = 1; i <= n; ++ i){
        cin >> a[i];
    }
    for(int i = 1; i <= n; ++ i){
        cin >> b[i];
    }
    cin >> Q;
    for(int i = 1; i <= Q; ++ i){
        int l, r;
        cin >> l >> r;
        q[r].emplace_back(l, i);
    }
    build(1, 1, n);
    int ta = 0, tb = 0;
    for(int i = 1; i <= n; ++ i){
        int la = i, lb = i;
        add(1, 1, n, i, i, ma(a[i]));
        // printf("%d %d %llu\n", i, i, a[i]);
        while(ta && a[sa[ta]] <= a[i]){
            // printf("%d %d %llu\n", sa[ta], la-1, a[i]-a[sa[ta]]);
            add(1, 1, n, sa[ta], la-1, ma(a[i]-a[sa[ta]]));
            la = sa[ta];
            -- ta;
        }
        a[la] = a[i];
        sa[++ta] = la;
        add(1, 1, n, i, i, mb(b[i]));
        while(tb && b[sb[tb]] <= b[i]){
            add(1, 1, n, sb[tb], lb-1, mb(b[i]-b[sb[tb]]));
            lb = sb[tb];
            -- tb;
        }
        b[lb] = b[i];
        sb[++tb] = lb;
        add(1, 1, n, 1, n, lsh());
        for(auto j : q[i]){
            ans[j.second] = ask(1, 1, n, j.first, i);
        }
        // printf("%llu\n", ask(1, 1, n, 1, n));
    }
    for(int i = 1; i <= Q; ++ i){
        cout << ans[i] << '\n';
    }
    return 0;
}

详细


Pretests


Final Tests

Test #1:

score: 4
Accepted
time: 3ms
memory: 15892kb

input:

1 30
12 28 21 20 26 9 6 10 27 1 16 19 30 5 2 25 4 3 29 17 7 14 8 22 24 13 23 11 18 15
12 29 4 25 24 18 2 1 26 22 10 14 13 9 21 8 16 11 7 23 27 17 20 5 30 15 6 19 3 28
30
1 30
2 24
1 24
1 23
4 28
6 30
2 23
4 29
5 28
4 29
3 28
4 28
5 26
4 30
1 25
21 26
27 30
8 15
2 23
1 30
17 27
4 20
3 23
18 23
3 4
7 ...

output:

336710
184007
203523
185997
225059
225153
167351
244869
206071
244869
244156
225059
169225
266125
224763
10602
3689
18312
167351
336710
39581
92768
148849
9978
1109
6894
106319
18113
50782
47053

result:

ok 30 lines

Test #2:

score: 4
Accepted
time: 2ms
memory: 16012kb

input:

2 30
10 17 6 8 11 25 3 12 18 27 19 24 4 2 22 15 26 21 13 29 1 28 5 9 7 20 23 30 16 14
2 22 19 20 5 14 1 25 30 24 27 18 21 4 23 15 8 12 13 29 9 28 6 10 3 16 17 11 26 7
30
1 30
3 24
2 28
2 27
4 25
5 27
4 28
4 30
7 28
7 28
1 30
8 30
8 29
1 27
1 25
9 28
4 27
13 25
7 30
1 4
1 6
2 23
15 28
6 13
5 26
4 22
...

output:

342792
179327
273851
252521
180248
197746
235091
278681
180251
180251
342792
199838
181594
271572
231039
146648
215561
58601
218441
2698
6741
177789
68964
22922
180622
131720
318248
6692
57156
148723

result:

ok 30 lines

Test #3:

score: 4
Accepted
time: 31ms
memory: 21144kb

input:

3 3000
353 828 1669 1982 2914 2076 2567 1457 1544 2684 2740 1321 2633 2048 2031 56 1523 1005 2808 1297 1259 2494 2270 1413 611 2423 1172 2329 1423 160 2510 944 1952 2500 1032 1072 2149 2883 2301 298 1783 791 1842 2505 147 2430 1098 1361 2044 118 643 2481 631 483 2477 2467 2551 1582 2330 866 835 716 ...

output:

40184823834717
26955803491255
22228935847946
25888117162514
23161821278709
22629748084474
20966308289652
30355251231971
29221320168914
28419961509740
23713745743311
21575766706848
35122192290088
32225006837037
19822682748069
34002609535683
25497598744349
25327366506625
22936542274243
32198777758697
...

result:

ok 3000 lines

Test #4:

score: 4
Accepted
time: 30ms
memory: 18520kb

input:

4 3000
2638 2598 731 140 1171 2511 1243 2680 1519 1460 2266 2053 2218 597 390 817 2038 1356 2174 2355 2783 42 262 2608 2157 19 703 631 1860 2840 573 1376 213 1058 1783 1188 1901 1785 1734 2141 2556 2376 906 1327 1464 2405 1339 2048 2005 110 1509 2551 431 2716 2652 722 502 1477 686 2319 891 80 1888 4...

output:

40206056459952
31102701371903
22040591903644
29242861635616
23150931329106
28470613252887
30683550840310
22462054969441
30942659939149
30565815940715
35688860808536
26119573396887
22224253959404
26093094410917
27127773484960
26463960447379
22310005535454
21359719514334
34109845370909
31436618773049
...

result:

ok 3000 lines

Test #5:

score: 4
Accepted
time: 30ms
memory: 20096kb

input:

5 3000
2249 537 2892 2283 2306 2418 31 1660 766 2489 2604 705 274 2387 179 2884 2367 1218 194 2341 1800 2722 2055 1390 2383 691 2560 2590 1612 2061 1830 2375 554 1301 401 450 733 2116 1210 2649 84 1657 1302 2028 1200 1347 793 929 2834 1600 1512 1102 490 649 1329 2403 1246 2312 1363 1736 2045 299 249...

output:

40215407189923
28473212930514
30689293264758
22464103417527
30946745354068
30573551559436
35696532341486
26123406341435
22222979171353
26100348250511
27135756380679
26469471376536
22316238161527
21363388695037
34117103848766
31442873240128
26775958078231
20402778389177
20064003507977
23564507607300
...

result:

ok 3000 lines

Test #6:

score: 4
Accepted
time: 888ms
memory: 80420kb

input:

6 100000
75396 38259 70632 44693 79241 97717 47646 85325 83810 92620 10842 2833 69920 53424 11573 42594 83445 5481 16123 10436 81601 67126 21529 83632 91675 53146 93935 75478 26177 10079 61996 62220 65571 17854 62571 44120 12071 28594 9282 43761 93433 50961 16593 95861 25192 62665 20974 92691 27730 ...

output:

13088889182779035269
6534221255345174303
1359726823929544631
2164887475632371239
318477223968383210

result:

ok 5 lines

Test #7:

score: 4
Accepted
time: 885ms
memory: 81336kb

input:

7 100000
63014 56265 32171 20204 73218 62 14769 68831 53214 29740 74162 95845 11373 74008 25172 29026 20301 54740 30487 83999 11075 78571 60955 20839 65241 12436 47345 41877 82265 71138 76247 70103 58369 34126 19769 85143 52047 81783 28431 69356 73486 7452 86080 81571 65219 5041 92975 32553 66188 85...

output:

13087680263309436773
12208176281181665354
5349200018910054316
8044281256248766983
20326974567770060

result:

ok 5 lines

Test #8:

score: 0
Time Limit Exceeded

input:

8 250000
102524 204126 191550 136652 234896 111850 90965 123593 106274 56675 82246 19895 57397 55004 46130 155550 39785 60103 122552 214968 216455 48719 166072 172777 104767 92024 32452 230050 103268 158821 178060 45135 204816 161747 91265 241770 97501 21273 203007 171576 242557 36395 161246 236301 ...

output:


result:


Test #9:

score: 0
Time Limit Exceeded

input:

9 250000
200098 97174 28170 173369 98549 34871 116482 220351 141539 159688 93550 139417 45870 191337 186976 147334 195549 152697 174924 168723 223082 182413 225141 21840 44011 60626 230775 79423 153938 5518 29510 41843 2318 10396 122588 34595 66572 245685 47998 67755 240326 101564 5965 202014 26201 ...

output:


result:


Test #10:

score: 4
Accepted
time: 944ms
memory: 79512kb

input:

10 100000
99999 99997 38376 6647 99995 45264 99994 60797 3686 19252 18126 99993 60719 5628 99992 32773 99990 99989 50339 47441 6259 99988 40227 39408 4332 54868 4905 99987 28891 99986 56608 3960 49232 52515 48642 99985 99983 38232 99982 42651 99981 15289 52368 47437 47335 14612 35407 7505 99980 1777...

output:

317658595255444763
18368397959953075616
280084360399151992
2583610329466235517
1533455168035

result:

ok 5 lines

Test #11:

score: 4
Accepted
time: 1017ms
memory: 80740kb

input:

11 100000
100000 30591 99999 99998 99997 6657 99996 99994 99992 38864 99991 20670 99990 99988 99987 99985 39155 99983 99982 99978 99976 27117 99974 99973 99967 24075 37813 99961 39325 30605 99964 99963 99962 99965 30090 99955 5617 18135 35997 99957 99956 28441 21161 5823 99958 99951 31145 99949 9994...

output:

13780806793530050287
17797854238990890570
5199674444197409071
8457812700909895353
800980143824327

result:

ok 5 lines

Test #12:

score: 0
Time Limit Exceeded

input:

12 250000
61524 87207 90471 27670 249999 16574 249998 146951 37265 36283 109285 23307 82928 249997 91608 78510 37152 149901 84119 96035 249994 249993 153324 36882 77439 113753 148205 249992 167295 124778 249990 169147 111261 126598 69467 249983 249989 30595 56533 58700 84977 249987 249984 32849 8844...

output:


result:


Test #13:

score: 0
Time Limit Exceeded

input:

13 250000
249999 249991 20376 249967 249987 249984 91555 249980 119971 249975 4184 82372 249974 249972 249968 121786 112458 62201 249988 249962 249961 113867 107713 120838 64384 22539 249959 114100 249957 55583 86376 120039 249955 249952 15133 249936 249934 249928 14071 86733 249926 31954 249917 965...

output:


result:


Test #14:

score: 4
Accepted
time: 1320ms
memory: 79656kb

input:

14 100000
3597 5516 55551 37736 24211 37914 21390 22526 46215 55934 32264 65310 42575 65276 24672 44887 19860 76191 20150 16092 13668 67517 49084 56403 12945 40511 43649 54874 58111 16947 79097 87926 41053 81714 85374 26502 49945 78788 4803 80183 46427 2335 68454 58827 34567 84916 54004 32408 38036 ...

output:

13088540581574624766
629284173226669726
468997573440049364
15354396477365723427
11288498399364179889
17327189088647249103
12769418610977411556
4638657286546655948
12658845491222164310
17426075592880655679
8948083376677040380
9972228259175586377
10791888668281039517
13868367556255097777
1591944218451...

result:

ok 100000 lines

Test #15:

score: 4
Accepted
time: 1315ms
memory: 81384kb

input:

15 100000
57947 32527 16708 9265 74780 96120 10235 79718 61290 9952 70460 34316 29410 32436 61691 94001 53555 61234 13140 32757 73723 32566 66354 71055 33746 66066 43476 59950 84762 44443 13470 79853 99700 10649 97877 73182 60586 86844 88176 7865 52949 56433 72723 58388 80743 52574 35199 95237 34911...

output:

13088703057356339375
9452829717979056783
10855633573936637367
15932473885595328514
15201582657253629696
13450475369980672385
8450776191038386557
8789636774986419618
8735359102250942459
10238677876572080533
10443715256660146761
16863804767088622984
15497692803706754695
8075678448199707171
15599621965...

result:

ok 100000 lines

Test #16:

score: 0
Time Limit Exceeded

input:

16 250000
66306 188910 58319 44602 94461 248619 191701 9283 84850 155848 129558 21149 14162 191976 24385 92838 106196 74117 86536 186052 195455 9505 57069 111387 232179 68871 71099 83805 245081 49405 4968 22277 102051 219152 53152 71844 85630 75109 149087 85840 203663 157740 17189 224588 125747 1654...

output:


result:


Test #17:

score: 0
Time Limit Exceeded

input:

17 250000
214518 7109 165693 60996 99727 33543 225083 68598 41778 4151 81497 40289 177818 156013 224688 237064 79616 21242 230963 161523 96814 51020 61668 19841 180565 177619 169253 1584 71948 103452 146421 146694 19330 30181 232433 161668 135488 88316 191971 24533 230674 125996 58536 131117 222030 ...

output:


result:


Test #18:

score: 4
Accepted
time: 1384ms
memory: 80096kb

input:

18 100000
199 11245 59248 15250 95721 77198 12068 47226 70219 94612 40882 78125 56325 81706 99564 57757 40981 16735 6520 37254 22399 45242 56303 18639 90538 5749 67746 10561 83841 8002 97391 44193 82633 47690 22491 88835 47085 11531 52728 90114 66975 84612 90065 10969 4360 66237 89606 281 78020 6408...

output:

6815616820806551949
7205429439063432118
15642689870296207430
3245952823108576149
11065941631556876399
2607022425032372237
9730308011167063463
6298877467219356716
9683954174931502382
3759342463774861788
6523546419874379014
4389383856772441835
7668291728724766969
16584967084166502935
95695822556053940...

result:

ok 100000 lines

Test #19:

score: 4
Accepted
time: 1405ms
memory: 79580kb

input:

19 100000
34498 55141 40963 75807 81840 89426 43863 32781 39782 31733 91313 97434 93531 80424 17034 16579 93540 26418 37633 70011 48786 19831 45883 38094 92295 72555 46747 21368 77539 18609 40907 88241 53467 7765 25009 41052 5111 20060 5059 51826 5359 71155 74408 47512 86754 66199 91733 11292 92220 ...

output:

2481761466351641555
986422971484149060
8658728699695364257
17851261996804073978
916152257861574538
15855025375517424187
10721715135603385812
3472831708317046634
14516646658494029447
13619176746086567018
3902068668827903455
5864881558079158416
14419266579987066772
16180430767487305565
226871722232768...

result:

ok 100000 lines

Test #20:

score: 0
Time Limit Exceeded

input:

20 250000
142345 136958 147947 150195 175778 238652 55360 166158 240487 70312 222146 26065 190856 62531 107895 54077 134731 76929 247840 99416 42360 132793 110469 176374 237332 180573 34058 148110 112862 150992 68053 6351 21165 227763 100676 238525 249762 94625 9877 57640 210186 121501 233338 103138...

output:


result:


Test #21:

score: 0
Time Limit Exceeded

input:

21 250000
159644 118111 87979 83677 241819 36594 90595 96968 114358 249598 220083 174210 179881 66939 78773 174346 232433 135387 133117 154375 202090 27468 211108 24017 129381 118539 138809 178525 234827 1082 189139 89875 205732 122496 60062 246324 87972 213698 81399 159352 109340 173047 119539 1451...

output:


result:


Test #22:

score: 4
Accepted
time: 1433ms
memory: 79956kb

input:

22 100000
99987 99992 99993 99990 99988 99991 99986 99982 99980 22717 3929 16263 29103 99979 99978 99977 99976 10865 99974 16993 99961 32111 99960 99957 99956 99949 26884 99947 23452 99946 22242 99945 99944 24237 99943 99938 99937 9438 12536 99935 99934 99930 99926 99922 99924 33917 3063 99923 99925...

output:

12296334484533229217
13339030993315175869
13090479388088811926
10482345934402558251
14606812070592042149
1191169862805405355
247267660434405450
13064213015389476904
4417588199022775781
17508586375392596219
16108134279804317852
16572022413825000678
1183556796563209024
15852127071992314873
13167456753...

result:

ok 100000 lines

Test #23:

score: 4
Accepted
time: 1410ms
memory: 82400kb

input:

23 100000
22584 33702 100000 37252 25122 17398 99998 99997 21290 99994 99990 99989 22335 22740 9312 99986 33821 99985 99984 99983 99979 99975 27331 99974 99973 13708 31617 99972 31130 13202 99971 99968 99967 3499 15101 99965 99964 99963 99962 36857 99960 37915 5196 10357 28557 14304 38089 27830 9995...

output:

15517502797221565608
12830304114960719956
4083489056006744671
6829605594922517664
15654051563504379394
4278503817148562008
7677371610297366733
14480009389326238220
5898746971631297662
4712939369321956375
16544777417349376055
17172668781345836613
16973850571062347363
2922394463132022392
1588208881951...

result:

ok 100000 lines

Test #24:

score: 0
Time Limit Exceeded

input:

24 250000
25471 61705 74365 249999 38625 85441 106054 12840 24109 3680 126059 249997 249995 249990 249989 249985 126496 119298 249984 19970 249983 57482 249982 249979 249978 59295 115702 17 80704 26932 249977 127802 45793 249976 249975 59578 249974 29119 48458 249973 18429 126811 126616 41549 249972...

output:


result:


Test #25:

score: 0
Time Limit Exceeded

input:

25 250000
250000 16831 249999 249998 23668 73080 81716 58206 249997 48474 249995 249993 36919 7843 249992 249989 249988 1992 50732 1225 51301 249987 249986 249983 249982 17515 249980 11033 28231 92583 249979 45096 59146 249978 249977 65779 249976 6789 249975 249974 249973 249972 19209 60855 47949 24...

output:


result: