QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#181989#4892. 序列hos_lyric#60 72ms72864kbC++145.8kb2023-09-17 07:24:132024-07-04 02:01:15

Judging History

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

  • [2024-07-04 02:01:15]
  • 评测
  • 测评结果:60
  • 用时:72ms
  • 内存:72864kb
  • [2023-09-17 07:24:13]
  • 提交

answer

#include <cassert>
#include <cmath>
#include <cstdint>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <bitset>
#include <complex>
#include <deque>
#include <functional>
#include <iostream>
#include <limits>
#include <map>
#include <numeric>
#include <queue>
#include <set>
#include <sstream>
#include <string>
#include <unordered_map>
#include <unordered_set>
#include <utility>
#include <vector>

using namespace std;

using Int = long long;

template <class T1, class T2> ostream &operator<<(ostream &os, const pair<T1, T2> &a) { return os << "(" << a.first << ", " << a.second << ")"; };
template <class T> ostream &operator<<(ostream &os, const vector<T> &as) { const int sz = as.size(); os << "["; for (int i = 0; i < sz; ++i) { if (i >= 256) { os << ", ..."; break; } if (i > 0) { os << ", "; } os << as[i]; } return os << "]"; }
template <class T> void pv(T a, T b) { for (T i = a; i != b; ++i) cerr << *i << " "; cerr << endl; }
template <class T> bool chmin(T &t, const T &f) { if (t > f) { t = f; return true; } return false; }
template <class T> bool chmax(T &t, const T &f) { if (t < f) { t = f; return true; } return false; }
#define COLOR(s) ("\x1b[" s "m")


struct Scc {
  int n;
  vector<int> as, bs;
  vector<int> ptr, zu, us;

  int l;
  vector<int> ids;
  int operator[](int u) const { return ids[u]; }

  explicit Scc(int n_) : n(n_), as(), bs(), l(-1) {}
  void ae(int u, int v) {
    assert(0 <= u); assert(u < n);
    assert(0 <= v); assert(v < n);
    as.push_back(u);
    bs.push_back(v);
  }

  void dfs0(int u) {
    if (!ids[u]) {
      ids[u] = -1;
      for (int i = ptr[u]; i < ptr[u + 1]; ++i) dfs0(zu[i]);
      us.push_back(u);
    }
  }
  void dfs1(int u) {
    if (!~ids[u]) {
      ids[u] = l;
      for (int i = ptr[u]; i < ptr[u + 1]; ++i) dfs1(zu[i]);
    }
  }
  void run() {
    const int m = as.size();
    ptr.resize(n + 2);
    zu.resize(m);
    for (int u = 0; u < n + 2; ++u) ptr[u] = 0;
    for (int i = 0; i < m; ++i) ++ptr[as[i] + 2];
    for (int u = 2; u < n + 1; ++u) ptr[u + 1] += ptr[u];
    for (int i = 0; i < m; ++i) zu[ptr[as[i] + 1]++] = bs[i];
    ids.assign(n, 0);
    us.clear();
    for (int u = 0; u < n; ++u) dfs0(u);
    for (int u = 0; u < n + 2; ++u) ptr[u] = 0;
    for (int i = 0; i < m; ++i) ++ptr[bs[i] + 2];
    for (int u = 2; u < n + 1; ++u) ptr[u + 1] += ptr[u];
    for (int i = 0; i < m; ++i) zu[ptr[bs[i] + 1]++] = as[i];
    l = 0;
    for (int j = n; --j >= 0; ) if (!~ids[us[j]]) { dfs1(us[j]); ++l; }
  }

  vector<vector<int>> group() const {
    assert(~l);
    vector<vector<int>> uss(l);
    for (int u = 0; u < n; ++u) uss[ids[u]].push_back(u);
    return uss;
  }
};


int med(int a, int b, int c) {
  return (a < b)
      ? ((a < c) ? ((b < c) ? b : c) : a)
      : ((b < c) ? ((a < c) ? a : c) : b);
}

int N, M;
int U[100'010][3];
vector<int> X;


namespace brute {
vector<int> run() {
  vector<int> perm(N);
  for (int u = 0; u < N; ++u) perm[u] = u;
  do {
    vector<int> xs(N, 0);
    for (int i = 0; i < M; ++i) {
      const int p = med(perm[U[i][0]], perm[U[i][1]], perm[U[i][2]]);
      if (!xs[p]) {
        xs[p] = X[i];
      }
      if (xs[p] != X[i]) {
        goto failed;
      }
    }
    {
      int x = 1;
      for (int p = 0; p < N; ++p) {
        if (!xs[p]) {
          xs[p] = x;
        }
        if (x > xs[p]) {
          goto failed;
        }
        x = xs[p];
      }
      vector<int> ans(N, -1);
      for (int u = 0; u < N; ++u) {
        ans[u] = xs[perm[u]];
      }
      return ans;
    }
   failed:{}
  } while (next_permutation(perm.begin(), perm.end()));
  return {};
}
}  // brute


namespace slow {
vector<int> run() {
  auto xs = X;
  sort(xs.begin(), xs.end());
  xs.erase(unique(xs.begin(), xs.end()), xs.end());
  const int xsLen = xs.size();
  Scc scc((N * (xsLen - 1)) << 1);
  // as[u] <= xs[j]
  auto le = [&](int u, int j) -> int {
    assert(0 <= j); assert(j < xsLen - 1);
    return (u * (xsLen - 1) + j) << 1;
  };
  // as[u] >= xs[j]
  auto ge = [&](int u, int j) -> int {
    assert(1 <= j); assert(j < xsLen);
    return (u * (xsLen - 1) + (j - 1)) << 1 | 1;
  };
  for (int u = 0; u < N; ++u) {
    for (int j = 1; j + 1 < xsLen; ++j) {
      scc.ae(ge(u, j + 1), ge(u, j));
      scc.ae(le(u, j - 1), le(u, j));
    }
  }
  for (int i = 0; i < M; ++i) {
    const int j = lower_bound(xs.begin(), xs.end(), X[i]) - xs.begin();
    for (int s = 0; s < 3; ++s) for (int t = 0; t < 3; ++t) if (s != t) {
      const int u = U[i][s];
      const int v = U[i][t];
      // (as[u] > xs[j]) ==> (as[v] <= xs[j])
      if (j + 1 < xsLen) scc.ae(ge(u, j + 1), le(v, j));
      // (as[u] < xs[j]) ==> (as[v] >= xs[j])
      if (j - 1 >= 0) scc.ae(le(u, j - 1), ge(v, j));
    }
  }
  scc.run();
  for (int z = 0; z < N * (xsLen - 1); ++z) if (scc[z << 1] == scc[z << 1 | 1]) {
    return {};
  }
  vector<int> ans(N, xs[0]);
  for (int u = 0; u < N; ++u) {
    for (int j = xsLen; --j > 0; ) {
      const int p = ge(u, j);
      if (scc[p] > scc[p ^ 1]) {
        ans[u] = xs[j];
        break;
      }
    }
  }
  return ans;
}
}  // slow


int main() {
  for (; ~scanf("%d%d", &N, &M); ) {
    X.resize(M);
    for (int i = 0; i < M; ++i) {
      scanf("%d%d%d%d", &U[i][0], &U[i][1], &U[i][2], &X[i]);
      --U[i][0];
      --U[i][1];
      --U[i][2];
    }
    
    const auto ans = slow::run();
    if (!ans.empty()) {
      puts("YES");
      for (int u = 0; u < N; ++u) {
        if (u) printf(" ");
        printf("%d", ans[u]);
      }
      puts("");
    } else {
      puts("NO");
    }
#ifdef LOCAL
const auto brt=brute::run();
cerr<<"brt = "<<brt<<endl;
#endif
  }
  return 0;
}

詳細信息

Subtask #1:

score: 20
Accepted

Test #1:

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

input:

10 10
6 3 10 133562624
8 7 6 685486592
4 2 7 332482851
10 8 9 211550017
2 10 1 165556251
10 8 5 211550017
6 8 2 332482851
4 9 2 332482851
8 1 4 193658790
9 6 10 728674154

output:

YES
165556251 332482851 133562624 193658790 211550017 728674154 685486592 211550017 728674154 133562624

result:

ok solution is correct

Test #2:

score: 0
Accepted
time: 1ms
memory: 3816kb

input:

10 9
5 3 7 489042696
10 9 3 489042696
5 9 4 589265757
1 3 7 489042696
9 3 10 489042696
2 8 7 402617168
2 4 5 564742148
1 8 3 615037121
2 8 4 564742148

output:

YES
615037121 402617168 489042696 564742148 589265757 402617168 402617168 615037121 589265757 489042696

result:

ok solution is correct

Test #3:

score: 0
Accepted
time: 1ms
memory: 4116kb

input:

9 9
3 8 4 385329352
1 4 5 826490084
4 5 9 866319564
2 4 1 449825973
8 3 5 385329352
6 2 9 88759441
3 6 9 88759441
6 8 9 385329352
4 8 1 449825973

output:

YES
449825973 88759441 88759441 866319564 826490084 88759441 88759441 385329352 866319564

result:

ok solution is correct

Test #4:

score: 0
Accepted
time: 1ms
memory: 3992kb

input:

10 10
1 9 6 957652738
9 7 1 934947905
9 10 8 507132050
5 2 8 162855738
2 2 8 537894544
9 9 9 266667281
3 3 8 158325440
2 7 9 752321309
10 3 1 104743493
4 10 10 799817379

output:

NO

result:

ok no solution

Test #5:

score: 0
Accepted
time: 1ms
memory: 3708kb

input:

8 9
7 4 7 187362209
5 1 1 634248682
2 3 2 664513540
3 2 4 161388361
5 1 3 463648080
8 1 6 485087787
6 3 6 689280466
3 6 8 116609606
7 2 7 399054929

output:

NO

result:

ok no solution

Test #6:

score: 0
Accepted
time: 1ms
memory: 3772kb

input:

10 8
5 6 10 861588864
10 1 8 608002433
8 3 4 196795234
1 8 3 285047219
9 7 5 480962478
6 10 1 780552157
3 4 2 190713929
7 5 6 780552157

output:

YES
285047219 190713929 196795234 190713929 861588864 780552157 480962478 608002433 480962478 861588864

result:

ok solution is correct

Test #7:

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

input:

10 5
6 5 1 644007358
4 2 1 644007358
8 5 1 672067709
7 2 1 845787134
9 8 5 672067709

output:

YES
644007358 845787134 644007358 644007358 672067709 644007358 845787134 672067709 672067709 644007358

result:

ok solution is correct

Test #8:

score: 0
Accepted
time: 1ms
memory: 3884kb

input:

9 6
9 6 3 408886589
3 2 1 680261634
8 4 1 540611446
6 3 2 680261634
5 2 1 540611446
7 3 2 680261634

output:

YES
408886589 680261634 680261634 540611446 540611446 408886589 680261634 540611446 408886589

result:

ok solution is correct

Subtask #2:

score: 10
Accepted

Test #9:

score: 10
Accepted
time: 8ms
memory: 5224kb

input:

40 9880
4 19 31 610502845
10 19 33 190412843
21 24 39 649028784
16 22 40 569593239
5 9 37 550862419
11 23 40 654613112
6 18 23 492267246
22 23 30 538715841
6 16 24 407919735
5 16 18 388907784
2 16 18 388907784
21 24 28 281403057
7 12 27 451830401
3 11 16 508407438
15 33 36 561955959
6 23 29 70605893...

output:

YES
877488996 197498120 508407438 610502845 209356929 706058934 655952999 624132238 550862419 32695410 654613112 72694954 399757770 396827347 561955959 407919735 779328631 388907784 190412843 657895429 832003778 569593239 492267246 32695410 718125822 812463588 451830401 281403057 877488996 538715841...

result:

ok solution is correct

Test #10:

score: 0
Accepted
time: 59ms
memory: 16840kb

input:

80 82160
8 15 41 111467584
35 54 58 471689837
51 66 69 545620573
20 63 76 46182451
15 34 40 54922534
19 27 49 410013534
6 13 18 849916477
3 12 30 436881726
8 23 54 239683045
6 37 40 544597112
29 52 70 792746131
7 52 75 478735558
11 50 74 735803963
4 28 50 415323204
23 54 68 347125331
33 67 70 525526...

output:

YES
325002529 459824851 295082589 415323204 815182959 942276740 478735558 111467584 372443066 865933468 870762944 436881726 849916477 838601559 30644239 942276740 236051181 278519554 906172939 46182451 284349661 777302867 514711056 91113251 393446574 393984539 410013534 478037910 848158501 839985283...

result:

ok solution is correct

Test #11:

score: 0
Accepted
time: 65ms
memory: 20624kb

input:

85 98770
27 63 76 248029292
25 30 35 550251757
48 53 54 313065504
4 25 37 610144939
74 75 85 456600945
21 75 79 276185205
8 11 84 490843403
19 42 64 531946207
16 30 81 443517377
8 50 68 108297273
51 53 83 535689817
20 35 74 550251757
3 10 63 602682982
3 41 75 456600945
59 77 83 737132984
27 55 71 24...

output:

YES
796868158 907723685 602682982 100984224 318471625 51502508 180796805 966425090 966425090 943508228 357852673 16220061 575720344 557367888 70281602 16220061 660516746 70390628 944390058 569820119 276185205 238004487 825967092 790137066 879681171 158633329 242047823 823251516 499099426 443517377 7...

result:

ok solution is correct

Test #12:

score: 0
Accepted
time: 62ms
memory: 22468kb

input:

85 98770
20 22 67 732656342
25 44 56 244626385
13 59 75 213697467
63 82 85 309272560
28 57 72 364782312
5 8 30 645939411
23 44 53 376754743
12 34 66 506119701
52 54 70 781735421
8 32 71 569597003
13 34 54 476762429
26 47 66 240658437
7 67 69 496620269
23 30 62 647373465
2 10 44 120620033
13 47 60 49...

output:

YES
853072217 84893870 84893870 744163096 645939411 830618471 496620269 496620269 200930742 120620033 380324990 506119701 49183774 530359747 530359747 718404242 606967479 113270399 861487950 175117549 732656342 732656342 376754743 244626385 244626385 240658437 464279351 364782312 54073243 647373465 ...

result:

ok solution is correct

Test #13:

score: 0
Accepted
time: 49ms
memory: 20252kb

input:

85 98770
21 32 83 503624580
20 39 69 305307880
44 45 57 876818763
10 25 41 522952359
19 62 71 613955167
54 63 74 177973416
6 61 71 360070176
51 52 60 541361998
13 33 46 503624580
2 43 73 68833128
12 55 63 459648386
45 66 67 521097301
29 45 76 307722318
2 19 43 82263839
37 62 69 193456165
54 62 77 53...

output:

YES
32323329 32323329 253295445 836531158 836531158 360070176 175567178 175567178 441708705 441708705 668511993 459648386 459648386 459648386 343676539 410730179 613955167 613955167 613955167 613955167 70655797 70655797 70655797 70655797 522952359 522952359 1538604 1538604 1538604 1538604 1538604 50...

result:

ok solution is correct

Test #14:

score: 0
Accepted
time: 64ms
memory: 20916kb

input:

85 98770
3 50 73 299752403
7 73 74 248077845
11 21 55 567953112
28 46 59 812646150
50 62 66 428307066
12 15 70 328727493
28 38 61 734761219
1 12 18 301543584
40 41 42 154591206
34 50 67 782539441
6 46 54 694114842
17 68 72 600618593
35 56 78 735071616
29 80 82 392386527
26 29 32 332472714
1 63 67 78...

output:

NO

result:

ok no solution

Test #15:

score: 0
Accepted
time: 65ms
memory: 20756kb

input:

85 98770
1 62 71 588317506
24 43 47 363838243
40 75 84 470529263
3 13 70 380819035
29 38 65 429982001
37 72 82 441727959
11 13 77 218506970
22 39 65 768340659
45 60 67 522712319
1 18 29 429982000
9 42 79 344491484
34 54 81 538619513
11 39 75 161544337
37 49 80 344491484
59 61 73 454057625
17 18 28 3...

output:

NO

result:

ok no solution

Subtask #3:

score: 30
Accepted

Dependency #1:

100%
Accepted

Test #16:

score: 30
Accepted
time: 35ms
memory: 44320kb

input:

1000 996
527 924 774 540173899
415 382 71 188751360
884 463 698 125924043
810 890 663 324838547
366 94 515 666179824
192 778 279 847431254
769 80 245 922736826
529 115 418 778769842
446 715 604 875242794
160 625 423 424822525
877 194 974 556338768
198 70 696 237534851
8 304 726 470021479
496 953 866...

output:

YES
2972186 2972186 670603801 824109436 194070621 614405181 356247025 420489663 2972186 950845418 609512045 609512045 857879636 824109436 626441474 607162501 664929448 2972186 409659940 703780779 640834798 585395354 766586241 441780827 209233215 734690663 439151771 2972186 846644135 169726917 324838...

result:

ok solution is correct

Test #17:

score: 0
Accepted
time: 72ms
memory: 72864kb

input:

996 1000
848 457 378 880385818
743 926 806 553228470
619 544 861 974849688
698 389 756 951371810
120 71 828 505821547
318 940 217 549943590
536 852 664 540115645
107 749 796 966841837
905 659 358 596025315
622 988 532 365141303
742 687 206 69113219
830 712 5 484296740
107 473 839 302448568
453 307 7...

output:

NO

result:

ok no solution

Test #18:

score: 0
Accepted
time: 42ms
memory: 42896kb

input:

990 988
723 217 736 529714749
380 396 260 409316596
716 401 619 788977572
232 40 909 164972335
323 646 767 742422834
71 268 229 498183446
695 825 949 605491713
447 539 73 644621097
420 81 160 368595699
425 287 797 536503051
385 36 451 515447677
952 980 356 506411673
149 355 67 955377149
726 594 192 ...

output:

YES
443272028 32792787 353952887 423457295 32792787 554132482 32792787 905142170 166672290 404755886 32792787 732938991 32792787 32792787 458153570 32792787 577930774 801254851 851220356 393414923 32792787 886695682 643346815 32792787 794870892 705435825 942112175 480960502 739916080 681118387 32792...

result:

ok solution is correct

Test #19:

score: 0
Accepted
time: 30ms
memory: 29528kb

input:

1000 992
358 307 292 715383877
889 622 482 680348743
106 61 16 780021827
967 840 355 799032574
7 6 2 371465877
886 277 143 488646126
196 7 6 325091271
292 274 172 378495286
356 297 226 247061041
298 136 30 288877994
399 191 33 108831408
595 350 48 342498526
406 5 3 666420994
321 146 69 878509167
699...

output:

YES
568892025 371465877 240147313 382659615 912032235 535835515 325091271 506493571 388344702 822893994 719429987 303866276 583326332 589898523 777989666 535270750 36369171 277896857 542030738 560500043 616674702 498011517 889586844 436151328 118249813 335897947 365646875 783512918 494764081 2139625...

result:

ok solution is correct

Test #20:

score: 0
Accepted
time: 35ms
memory: 40856kb

input:

1000 995
93 88 83 205161273
59 54 47 272815050
976 968 967 128081945
491 486 476 163208281
964 960 953 393463398
126 122 119 919973605
251 243 241 268012077
401 398 390 888396262
786 777 773 821327852
264 256 250 387688185
107 104 95 764563667
198 195 185 421528348
18 14 4 465222052
163 154 149 4425...

output:

YES
465222052 27884338 420272005 465222052 420272005 725814201 465222052 554351793 757386571 554351793 290177907 465222052 164869035 465222052 578945293 725814201 574834092 774812229 508474159 527586554 465222052 475145071 574834092 854236804 757386571 508474159 164869035 305048016 508663785 2252654...

result:

ok solution is correct

Test #21:

score: 0
Accepted
time: 39ms
memory: 45904kb

input:

1000 1000
556 922 96 247240976
370 478 526 363454712
150 642 778 518784471
643 799 624 143452980
802 129 973 753138409
199 215 390 501598040
583 526 122 48846823
854 611 985 605244939
49 338 443 128617908
273 232 409 244385789
653 658 559 488952689
407 210 464 433805586
585 90 940 614614430
200 884 ...

output:

NO

result:

ok no solution

Test #22:

score: 0
Accepted
time: 17ms
memory: 41508kb

input:

1000 998
629 816 724 126263144
621 897 391 796546541
696 322 185 803804896
305 790 889 153079778
330 652 692 609221623
253 703 517 578803480
537 563 346 245597626
231 706 863 483185655
480 852 407 473711558
156 1 967 762984005
842 945 498 943018627
513 799 78 86152666
703 517 550 578803480
168 506 9...

output:

YES
535370966 653909866 527164019 875149419 704759861 576529855 159013463 545426727 693134038 15823871 15823871 15823871 537710478 906800639 15823871 15823871 756105032 461649456 603236285 603236285 15823871 459871381 864400294 505777059 305616160 727284214 642678444 642678444 15823871 15823871 4389...

result:

ok solution is correct

Test #23:

score: 0
Accepted
time: 19ms
memory: 29256kb

input:

1000 997
357 347 345 733358338
682 672 663 209734493
393 387 380 305734825
627 626 625 324357526
928 919 914 438604806
625 616 610 417853070
540 537 531 807315869
886 885 878 777205250
752 750 748 348526994
679 678 675 276712558
970 969 961 376456558
518 516 506 571223812
264 256 255 562733931
23 20...

output:

YES
997630534 997630534 21980339 666922803 787030151 251259941 787030151 410528085 284506465 666922803 785449789 785449789 375712613 251259941 251259941 251259941 301736605 410528085 666922803 187474183 138591831 284506465 449165229 483096393 301736605 885066723 369361134 138591831 483096393 1874741...

result:

ok solution is correct

Test #24:

score: 0
Accepted
time: 16ms
memory: 41296kb

input:

1000 998
188 595 689 592674202
126 841 768 505688775
274 1000 351 565885054
767 460 705 439050630
61 626 381 387458774
607 444 978 618476232
264 583 900 850042952
53 722 698 40237254
482 112 552 162817181
242 545 956 648781127
964 186 989 830125903
475 685 786 521769463
841 768 13 478559108
409 443 ...

output:

NO

result:

ok no solution

Test #25:

score: 0
Accepted
time: 18ms
memory: 30844kb

input:

1000 997
224 221 215 685183418
765 756 753 345268843
880 874 871 547734181
796 787 778 764396807
480 470 469 896165180
700 698 690 500019202
450 442 438 667969122
151 146 141 549351752
819 810 804 186861970
537 531 527 310783900
884 881 873 888208832
590 588 583 659624517
152 150 144 323089371
618 6...

output:

NO

result:

ok no solution

Subtask #4:

score: 0
Runtime Error

Dependency #2:

100%
Accepted

Dependency #3:

100%
Accepted

Test #26:

score: 0
Runtime Error

input:

100000 100000
81017 10545 55789 799774881
62032 98611 26850 622879245
3899 20450 37728 411720977
93833 22867 66256 400655546
99733 95937 76629 869108615
42977 7684 86924 766643875
92542 5317 44655 804443432
40897 86851 13377 394123873
69459 57362 2359 451550287
93737 83595 69209 670362145
45236 2844...

output:


result: