QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#864806#5034. >.<winsun70 301ms102004kbC++144.6kb2025-01-21 08:43:192025-01-21 08:43:20

Judging History

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

  • [2025-01-21 08:43:20]
  • 评测
  • 测评结果:70
  • 用时:301ms
  • 内存:102004kb
  • [2025-01-21 08:43:19]
  • 提交

answer

#include <cstdio>
#include <cstring>
#include <cmath>
#include <cassert>
#include <algorithm>
#include <queue>
#include <vector>
#include <map>
#define fi first
#define se second
using namespace std;
typedef long long LL;
typedef pair<int, int> pii;

bool Mst;

template <typename Tp> void read(Tp &x) {
    char ch; bool op = 0; x = 0;
    do ch = getchar(), op |= ch == '-'; while (ch < '0' || ch > '9');
    do x = (x<<3)+(x<<1)+(ch&15), ch = getchar(); while (ch >= '0' && ch <= '9');
    if (op) x = -x;
}

const int MAXN = 4e5+5;
const int mod = 998244353;

inline int fplus(int x, int y) { return x + y >= mod ? x + y - mod : x + y; }
inline int Fplus(int& x, int y) { return x = fplus(x, y); }
inline int Fminus(int& x, int y) { return x = fplus(x, mod - y); }

map<pair<int, int>, LL> w;
priority_queue<pair<LL, int> > pq;
LL dis[MAXN]; 
bool vis[MAXN], ed[MAXN];

namespace SGT {
    const int SIZ = MAXN<<6;
    int lc[SIZ], rc[SIZ], s[SIZ], tot;
    bool vis[SIZ];
    int copy(int x) {
        int y = ++tot;
        lc[y] = lc[x], rc[y] = rc[x], s[y] = s[x];
        return y;
    }
    #define mid ((l + r) >> 1)
    void update(int& x, int l, int r, int p, int v) {
        x = copy(x);
//        fprintf(stderr, "%d [%d,%d], %d %d\n", x, l, r, p, v); 
        if (l == r) return s[x] = v, void();
        if (p <= mid) update(lc[x], l, mid, p, v);
        else update(rc[x], mid+1, r, p, v);
    }
    int query(int x, int l, int r, int p) {
        if (l == r) return s[x];
        if (p <= mid) return query(lc[x], l, mid, p);
        else return query(rc[x], mid+1, r, p);
    }
    void dfs(int x, int l, int r, int u, LL d) {
        if (!x || vis[x]) return;
        vis[x] = 1;
        if (l == r) {
            int v = l, y = s[x];
            if (!ed[y]) {
//                printf("%d %d %d\n", u, v, y); 
                assert(w.count(make_pair(u, v)));
                if (dis[y] > d + w[make_pair(u, v)]) {
                    dis[y] = d + w[make_pair(u, v)];
                    pq.emplace(-dis[y], y);
                }
            }
            return;
        }
        dfs(lc[x], l, mid, u, d), dfs(rc[x], mid+1, r, u, d);
    }
    #undef mid
} 

int n, m, k, rt[MAXN];

namespace ACAM {
    map<int, int> son[MAXN];
    const int root = 0;
    int fail[MAXN], val[MAXN], tot=root;
    void insert(const vector<int>& vec, bool op = true) {
        int x = root;
        for (int ch : vec) {
            if (!son[x].count(ch)) son[x][ch] = ++tot;
            x = son[x][ch];
        }
        ed[x] |= op;
    }
    void build() {
        queue<int> q;
        for (pii p:son[root]) {
            assert(p.fi == p.se);
            val[p.se] = p.fi, fail[p.se] = root;
            q.emplace(p.se);
        }
        while (!q.empty()) {
            int x = q.front(); q.pop();
            if (fail[x]) ed[x] |= ed[fail[x]], rt[x] = rt[fail[x]];
            for (pii p:son[x]) {
                int y = p.se, c = p.fi;
                fail[y] = SGT::query(rt[x], 1, n, c);
//                fprintf(stderr, "%d %d\n", x, c);
                assert(fail[y]);
                SGT::update(rt[x], 1, n, c, y);
                val[y] = c;
                q.emplace(y);
            }
        }
    }
}

void dijkstra() {
    memset(dis, 0x3f, sizeof(dis));
    dis[1] = 0;
    pq.emplace(0, 1);
    while (!pq.empty()) {
        int nd = pq.top().se; pq.pop();
        assert(!ed[nd]);
        if (vis[nd]) continue;
        vis[nd] = 1;
        SGT::dfs(rt[nd], 1, n, ACAM::val[nd], dis[nd]);
    }
}

bool Med;

int main() {
    #ifndef ONLINE_JUDGE
    freopen("qoj5034.in", "r", stdin);
    freopen("qoj5034.out", "w", stdout);
    fprintf(stderr, "%lf\n", (&Mst - &Med) / 1048576.0); 
    #endif
    read(n), read(m), read(k);
    for (int i = 1; i <= n; ++i) ACAM::insert({i}, 0);
    for (int i = 1, x, y, v; i <= m; ++i) {
        read(x), read(y), read(v), w[make_pair(x, y)] = v;
        SGT::update(rt[x], 1, n, y, y);
    }
    for (int i = 1; i <= k; ++i) {
        int len; read(len);
        vector<int> path; path.resize(len);
        for (int i = 0; i < len; ++i) read(path[i]);
        ACAM::insert(path);
    }
    ACAM::build();
    dijkstra();
    LL ans = 0x3f3f3f3f3f3f3f3f;
    for (int i = 1; i <= ACAM::tot; ++i) {
        if (ACAM::val[i] == n) {
            ans = min(ans, dis[i]);
//            printf("%d %d %lld %d\n", i, ACAM::val[i], dis[i], ed[i]);
        }
    }
    if (ans == 0x3f3f3f3f3f3f3f3f) puts("-1");
    else printf("%lld\n", ans);
    return 0;
}

详细

Subtask #1:

score: 20
Accepted

Test #1:

score: 20
Accepted
time: 2ms
memory: 30704kb

input:

35 100 0
34 7 447733879
24 20 187005344
14 34 654502303
2 31 865194349
20 33 9517055
33 15 991889891
24 33 395599993
13 16 237525328
9 5 373850826
30 34 391470240
10 7 650077565
26 10 400825980
34 27 189924713
19 27 907609573
20 10 614945312
10 5 960007605
1 7 984076202
32 25 539699728
24 31 2553027...

output:

1970522617

result:

ok single line: '1970522617'

Test #2:

score: 20
Accepted
time: 0ms
memory: 31084kb

input:

35 100 0
3 12 720466531
8 12 396056603
29 21 717362482
34 13 785882968
7 13 748993858
9 28 371041056
5 22 279747660
10 13 511029466
9 10 90421686
24 13 68485905
12 17 589986641
26 3 49095373
15 24 515201376
10 33 672973479
29 31 705185599
27 22 689337965
20 4 145960570
31 28 136121037
28 5 202143094...

output:

2296067497

result:

ok single line: '2296067497'

Test #3:

score: 20
Accepted
time: 2ms
memory: 33980kb

input:

35 100 0
22 20 355360466
23 35 601550723
3 27 186544474
6 24 134507727
25 2 672165808
19 1 711018563
32 16 669385420
27 11 750652665
14 11 158441860
25 14 53347528
2 20 140122295
33 20 112964489
14 6 253781013
18 14 771123144
17 35 508607402
3 19 403442205
30 16 336645858
24 22 470183063
31 22 10734...

output:

1517028140

result:

ok single line: '1517028140'

Test #4:

score: 20
Accepted
time: 1ms
memory: 34032kb

input:

35 100 0
32 5 808438527
26 23 888346324
14 19 992303007
23 1 278329540
17 29 587913784
4 33 770924125
2 5 605204525
1 21 657667587
9 35 444108546
22 12 391857443
31 33 184589665
7 14 826884170
10 32 241928783
3 17 634515992
9 34 429624654
1 18 736971857
6 9 625772037
20 18 344038507
12 25 24408330
4...

output:

1502429426

result:

ok single line: '1502429426'

Test #5:

score: 20
Accepted
time: 2ms
memory: 34412kb

input:

35 100 0
1 9 150223804
13 25 225623874
27 10 826064515
7 31 111586392
27 4 627187519
8 7 517189480
10 13 427167940
24 14 563496
27 23 119441879
13 31 712972744
34 13 128158051
16 13 146964967
31 14 860155206
25 5 431208773
24 11 48709486
29 10 694088474
11 1 801122521
12 10 369399315
21 29 399505482...

output:

1355451140

result:

ok single line: '1355451140'

Subtask #2:

score: 20
Accepted

Dependency #1:

100%
Accepted

Test #6:

score: 20
Accepted
time: 1ms
memory: 31212kb

input:

35 100 10
11 2 380526516
9 1 213280408
20 1 775174358
23 33 14349082
32 11 781584201
10 26 572662203
8 12 157664649
23 20 327195474
15 25 861545590
6 18 838910534
21 27 91640650
19 26 995166014
4 2 878565098
4 34 523383573
26 18 578962566
31 6 874478934
11 8 398592349
10 7 643306798
13 28 290421417
...

output:

1980354133

result:

ok single line: '1980354133'

Test #7:

score: 20
Accepted
time: 0ms
memory: 30576kb

input:

35 100 10
11 1 896687117
7 26 476711390
5 32 630956
6 4 823883738
21 34 247010132
3 12 913937169
16 12 430385321
16 5 852671069
26 21 985342803
30 6 434242228
29 8 425264910
4 20 270204170
30 29 682115837
17 15 583261079
26 28 747023051
34 5 467933832
8 35 286976257
18 28 122472413
17 2 139111605
31...

output:

1221466953

result:

ok single line: '1221466953'

Test #8:

score: 20
Accepted
time: 2ms
memory: 31340kb

input:

35 100 10
22 1 14962104
21 6 543325859
8 34 566018166
33 20 98618235
25 17 262818303
12 20 406329400
8 18 609453514
24 2 538644514
9 19 692253675
2 35 402502466
6 22 643342764
32 22 125016732
24 15 592478175
9 4 983207384
27 1 8572978
33 11 455386297
8 6 80900833
21 18 876759575
6 3 498241363
3 27 7...

output:

2366165329

result:

ok single line: '2366165329'

Test #9:

score: 20
Accepted
time: 1ms
memory: 32496kb

input:

35 100 10
9 11 824356486
26 28 495355000
18 7 722666675
13 28 916320626
23 5 902191290
24 15 565350882
7 25 395415147
1 15 174378000
32 27 314954867
32 4 620502039
14 8 369888464
30 10 174528922
19 8 225961839
3 18 287338530
32 6 194825575
4 7 434071787
26 22 760578181
2 14 778364759
15 21 672777506...

output:

4621773448

result:

ok single line: '4621773448'

Test #10:

score: 20
Accepted
time: 1ms
memory: 33904kb

input:

35 100 10
8 1 955842345
8 26 487841115
13 11 431659053
32 35 736554102
34 8 223723748
2 6 474854267
10 13 343831244
9 31 652218719
33 21 18870804
21 3 657281305
33 30 354153202
13 29 96716199
13 7 930885678
28 2 403915674
12 7 428085923
9 28 518591614
27 33 676639919
7 16 293763983
29 21 317079692
8...

output:

-1

result:

ok single line: '-1'

Subtask #3:

score: 30
Accepted

Test #11:

score: 30
Accepted
time: 255ms
memory: 90136kb

input:

50000 200000 1
7542 37166 116613326
3581 43961 629220971
12873 42953 440313807
31744 5286 697832848
25882 12748 106667302
34760 29676 181570340
41570 9240 885513989
22227 35688 63657981
43180 29194 174058940
8977 41899 48262624
7465 18291 600002514
46925 9281 951474878
2115 31162 373758881
5386 3798...

output:

2526392504

result:

ok single line: '2526392504'

Test #12:

score: 30
Accepted
time: 259ms
memory: 90044kb

input:

50000 200000 1
24782 12463 176168576
48875 16935 741763277
36966 21304 496529510
23163 41091 139899126
22017 12255 642957842
20239 21407 267962408
9992 39550 648664588
46678 18079 745576109
21525 40647 668173200
15499 45167 948835398
236 25231 504169193
1144 26236 160922096
5068 22529 596773743
2293...

output:

2916905009

result:

ok single line: '2916905009'

Test #13:

score: 30
Accepted
time: 253ms
memory: 91632kb

input:

50000 200000 1
44987 47473 603921908
19076 14543 979792861
40477 5097 975772708
10156 43592 986014532
38276 14331 883008937
27568 17017 379894398
20669 13688 619117263
10452 28268 302961670
49932 14669 219573245
21299 37089 111817304
166 9139 579564241
39624 47105 454768157
36321 44135 475008487
154...

output:

2437330315

result:

ok single line: '2437330315'

Test #14:

score: 30
Accepted
time: 278ms
memory: 90076kb

input:

50000 200000 1
23044 25813 938979371
13825 12053 600535744
40300 48533 976220497
27950 9733 185539918
17753 40163 441723428
16971 12159 195868379
46052 16991 663733811
7358 22733 618903475
2686 14738 147547542
35603 33025 563640588
27600 13132 146407801
4349 35144 646562628
34069 5239 661848564
2670...

output:

2525861695

result:

ok single line: '2525861695'

Test #15:

score: 30
Accepted
time: 272ms
memory: 93368kb

input:

50000 200000 1
7010 49706 41082166
103 46014 91170674
28554 6661 235249419
24817 37664 390481853
21256 38170 713774964
5638 33537 671772217
18117 23810 806403210
4928 24506 263165151
19583 15308 101634127
1571 48099 527342772
46438 27069 966211201
12628 13976 545976032
48175 1310 804025336
22339 471...

output:

2343184542

result:

ok single line: '2343184542'

Subtask #4:

score: 0
Runtime Error

Dependency #2:

100%
Accepted

Dependency #3:

100%
Accepted

Test #16:

score: 30
Accepted
time: 294ms
memory: 100556kb

input:

100000 200000 1000
19301 9982 475809376
52647 57952 928799166
9946 15118 40293182
66459 51732 326545014
80330 52390 715066088
31148 24539 119871789
57032 47286 947993583
98743 49894 241867216
60086 21505 368954791
91768 49801 542930073
60256 30453 412799483
36211 89359 653932077
45566 53313 15684003...

output:

8083327502

result:

ok single line: '8083327502'

Test #17:

score: 30
Accepted
time: 296ms
memory: 97876kb

input:

100000 200000 1000
80075 68116 142970144
36601 15061 355242020
92568 95586 525501865
88685 38697 187866032
14520 30560 541191778
56724 37390 515750178
18884 72571 242089567
41181 98841 550088819
65162 48127 817224281
74290 68998 694769252
14496 15293 240590474
93890 16543 306889224
76237 85271 38310...

output:

6805440468

result:

ok single line: '6805440468'

Test #18:

score: 30
Accepted
time: 301ms
memory: 102004kb

input:

100000 200000 1000
54902 45565 209744243
7916 74828 542255326
74913 75406 694953563
60977 27774 696350584
4357 78374 695819954
73651 93310 927896743
78422 69874 765148628
4340 11648 831353168
73481 54277 159880801
30642 18345 948964021
12981 62022 492589556
42037 69233 157973044
64535 41068 51105435...

output:

6889144412

result:

ok single line: '6889144412'

Test #19:

score: 30
Accepted
time: 273ms
memory: 97008kb

input:

100000 200000 1000
75982 60451 883166605
68067 20900 877134639
51374 19523 268232604
29382 99013 305216607
1991 26063 982636024
53030 72285 849876664
86016 44259 426860064
74173 17758 236299680
31639 57016 119442138
59029 31790 496971527
41939 33688 647056718
91622 87349 884517745
31301 53781 125813...

output:

4650222261

result:

ok single line: '4650222261'

Test #20:

score: 0
Runtime Error

input:

100000 199996 49998
1 2 1
2 50000 1
1 3 1
3 50000 1
1 4 1
4 50000 1
1 5 1
5 50000 1
1 6 1
6 50000 1
1 7 1
7 50000 1
1 8 1
8 50000 1
1 9 1
9 50000 1
1 10 1
10 50000 1
1 11 1
11 50000 1
1 12 1
12 50000 1
1 13 1
13 50000 1
1 14 1
14 50000 1
1 15 1
15 50000 1
1 16 1
16 50000 1
1 17 1
17 50000 1
1 18 1
1...

output:


result: