QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#817230#4743. RóżnorodnośćJEdward100 ✓3015ms132820kbC++202.2kb2024-12-16 21:01:422024-12-16 21:01:42

Judging History

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

  • [2024-12-16 21:01:42]
  • 评测
  • 测评结果:100
  • 用时:3015ms
  • 内存:132820kb
  • [2024-12-16 21:01:42]
  • 提交

answer

#include <iostream>
#include <vector>
#include <algorithm>
#include <map>
int n, m, k;
std::vector<std::vector<int>> a, d;
std::map<int, int> s;
std::vector<std::vector<int>> pos;
int main() {
    std::ios::sync_with_stdio(false);
    std::cin.tie(nullptr);
    std::cin >> n >> m >> k;
    a.assign(n, std::vector<int>(m));
    int maxA = 0;
    for (int i = 0; i < n; ++i) {
        for (int j = 0; j < m; ++j) {
            std::cin >> a[i][j];
            maxA = std::max(maxA, a[i][j]);
            --a[i][j];
        }
    }
    pos.resize(maxA);
    for (int i = 0; i < n; ++i)
        for (int j = 0; j < m; ++j)
            pos[a[i][j]].push_back(i * m + j);
    d.assign(n - k + 2, std::vector<int>(m - k + 2));
    for (int v = 0; v < maxA; ++v) {
        s.clear();
        s[0] = 0;
        s[m - k + 1] = -1;
        for (int p : pos[v]) {
            int x = p / m + 1, y = p % m + 1;
            int u = std::max(0, x - k), l = std::max(0, y - k);
            x = std::min(x, n - k + 1);
            y = std::min(y, m - k + 1);
            s[y] = std::prev(s.upper_bound(y)) -> second;
            auto it = std::prev(s.upper_bound(l));
            int up = std::max(it -> second, u), rt = std::next(it) -> first;
            ++d[up][l];
            --d[up][rt];
            --d[x][l];
            ++d[x][rt];
            ++it;
            s[l] = x;
            while (it -> first != y) {
                up = std::max(it -> second, u);
                int lf = it -> first;
                it = s.erase(it);
                rt = it -> first;
                ++d[up][lf];
                --d[up][rt];
                --d[x][lf];
                ++d[x][rt];
            }
        }
    }
    for (int i = 0; i <= n - k + 1; ++i)
        for (int j = 1; j <= m - k + 1; ++j)
            d[i][j] += d[i][j - 1];
    for (int i = 1; i <= n - k + 1; ++i)
        for (int j = 0; j <= m - k + 1; ++j)
            d[i][j] += d[i - 1][j];
    int max = 0;
    long long sum = 0;
    for (int i = 0; i < n - k + 1; ++i) {
        for (int j = 0; j < m - k + 1; ++j) {
            max = std::max(max, d[i][j]);
            sum += d[i][j];
        }
    }
    std::cout << max << " " << sum << "\n";
    return 0;
}

Details

Tip: Click on the bar to expand more detailed information

Subtask #1:

score: 10
Accepted

Test #1:

score: 10
Accepted
time: 0ms
memory: 3628kb

input:

3 5 2
1 5 3 3 3
4 1 3 3 4
4 2 4 4 3

output:

4 20

result:

points 1.0 read (4 20), answer is (4 20)

Test #2:

score: 10
Accepted
time: 4ms
memory: 6040kb

input:

100 100 10
91306 51479 54826 75223 35428 85264 75004 65924 21947 6904 8963 238 45279 67937 69262 197 73305 97207 47430 10715 53574 72318 80995 2100 58351 42451 71480 58479 47271 14042 37966 64247 68664 60734 38622 60010 20065 17992 10679 23838 78816 33323 86014 44651 6705 47297 82184 3143 56316 4527...

output:

100 827720

result:

points 1.0 read (100 827720), answer is (100 827720)

Test #3:

score: 10
Accepted
time: 7ms
memory: 5768kb

input:

100 100 50
64496 38874 48189 11899 33120 21851 53413 48452 59973 92990 80131 95134 61257 66659 99155 70782 9812 58126 93021 16288 12001 34171 26503 97321 39686 44903 6830 75325 92471 30121 8878 84556 42748 15619 53158 249 99909 3303 31069 38472 70566 43888 78572 48496 76411 62834 41068 87383 65776 8...

output:

2461 4934018

result:

points 1.0 read (2461 4934018), answer is (2461 4934018)

Test #4:

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

input:

100 99 10
54966 24501 49186 8761 98087 62704 46742 20275 55333 31056 3316 1522 47428 12673 79139 49186 67062 12575 76801 28656 40880 97132 71122 64898 53558 7824 55333 52030 34197 38563 81163 61038 94168 95662 27212 60371 77054 96664 48234 46004 89724 9825 59941 62188 25732 62688 30273 61545 7746 50...

output:

99 743402

result:

points 1.0 read (99 743402), answer is (99 743402)

Test #5:

score: 10
Accepted
time: 7ms
memory: 5756kb

input:

77 100 48
65113 40586 77535 74708 35660 7422 12773 34227 67276 59851 55836 26908 50992 29709 32592 54485 37822 80836 85471 89027 27520 84363 83749 85177 63590 91437 9837 44480 19273 68621 87795 35212 15194 35214 26336 87995 66796 50605 8441 85031 89625 18644 579 74637 18526 71917 34547 22258 67907 1...

output:

2270 3585449

result:

points 1.0 read (2270 3585449), answer is (2270 3585449)

Test #6:

score: 10
Accepted
time: 3ms
memory: 5716kb

input:

100 100 100
40193 76965 66973 15861 36722 31393 40205 54166 47864 19556 69661 13235 6988 69616 60048 34495 87573 25362 90962 72124 70512 91262 24810 27503 21691 86430 108 787 69795 72772 66208 41811 47875 36008 43416 63755 31020 27226 79287 29143 48600 85038 81493 60514 29384 80776 67363 44177 42946...

output:

9267 9267

result:

points 1.0 read (9267 9267), answer is (9267 9267)

Test #7:

score: 10
Accepted
time: 0ms
memory: 3592kb

input:

3 3 2
2 2 1
2 1 1
1 2 1

output:

2 8

result:

points 1.0 read (2 8), answer is (2 8)

Test #8:

score: 10
Accepted
time: 1ms
memory: 3676kb

input:

20 100 10
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 ...

output:

19 19019

result:

points 1.0 read (19 19019), answer is (19 19019)

Subtask #2:

score: 10
Accepted

Test #9:

score: 10
Accepted
time: 92ms
memory: 9396kb

input:

500 600 20
9042 72142 87980 57669 71456 73645 50464 87980 381 11369 81915 15547 18828 12406 35258 24586 50678 9028 5258 31692 61388 21878 68402 51732 31692 18347 85203 28349 47466 33500 15996 90722 87875 36339 18347 91251 67303 96279 57669 34595 38664 44806 750 83771 57500 9042 11625 11625 54591 218...

output:

100 27442112

result:

points 1.0 read (100 27442112), answer is (100 27442112)

Test #10:

score: 10
Accepted
time: 24ms
memory: 7052kb

input:

500 312 150
40498 26427 34930 91737 14640 39502 47569 37881 72731 82817 39502 20629 37345 21521 37646 21875 39502 34930 36028 37881 92237 41047 97318 30759 69561 89609 91737 67742 58867 35221 37881 6061 82817 48897 68348 96467 90436 23408 42540 83596 9278 89609 56847 17958 54135 73224 20629 29360 79...

output:

99 5629364

result:

points 1.0 read (99 5629364), answer is (99 5629364)

Test #11:

score: 10
Accepted
time: 80ms
memory: 8700kb

input:

500 599 30
25379 6767 25379 1162 6767 13531 13531 57620 13531 57620 13531 6767 57620 1162 6767 6767 6767 6767 6767 13531 6767 1162 25379 6767 1162 57620 13531 57620 25379 13531 6767 6767 6767 1162 1162 6767 25379 57620 1162 57620 25379 25379 25379 1162 25379 57620 6767 13531 1162 13531 25379 6767 25...

output:

6 1350720

result:

points 1.0 read (6 1350720), answer is (6 1350720)

Test #12:

score: 10
Accepted
time: 37ms
memory: 8508kb

input:

600 500 298
58302 64277 8389 79078 61986 50373 78876 58302 57350 1896 41918 64678 73366 75168 94586 73366 19884 47757 44739 64277 75716 8389 53185 69281 62367 41918 377 61986 77711 92306 79078 5427 57350 64678 58302 23544 41918 43122 8389 97345 94586 8389 103 57737 62367 53185 1896 9855 79078 99499 ...

output:

56 3206707

result:

points 1.0 read (56 3206707), answer is (56 3206707)

Test #13:

score: 10
Accepted
time: 46ms
memory: 9152kb

input:

599 597 300
34303 96991 52163 47668 81969 95509 14004 46249 52163 21323 14004 42397 54380 14004 78341 58801 85277 43134 48361 52163 61744 61744 73008 59383 96761 79835 62658 96991 13437 93321 34236 75984 66159 34303 11047 21323 53494 48636 96761 62658 96761 81969 11047 47668 42397 79835 84761 50514 ...

output:

100 8940000

result:

points 1.0 read (100 8940000), answer is (100 8940000)

Subtask #3:

score: 20
Accepted

Dependency #1:

100%
Accepted

Test #14:

score: 20
Accepted
time: 79ms
memory: 11848kb

input:

600 600 100
53169 75015 3584 33705 94686 32491 68237 16354 84798 12258 67365 5443 63163 33255 61895 81897 61002 44897 3873 19255 21129 17753 4138 69104 63785 73638 36739 8697 71733 77413 62370 5534 18298 6794 98480 20942 27018 15585 75412 92609 33049 80876 51622 42965 25392 61287 24420 31124 22381 6...

output:

9592 2387932623

result:

points 1.0 read (9592 2387932623), answer is (9592 2387932623)

Test #15:

score: 20
Accepted
time: 77ms
memory: 12088kb

input:

600 600 5
6968 24815 93646 84863 77609 40598 6011 43001 25469 32756 25213 31187 48747 87097 96833 50761 39568 69951 75376 69367 40233 5286 44891 20310 32750 94523 50398 81886 8358 51824 31767 78540 46698 71141 14943 32554 72771 48349 87867 273 22645 54876 37689 23303 21366 72771 93429 64309 93486 64...

output:

25 8400862

result:

points 1.0 read (25 8400862), answer is (25 8400862)

Test #16:

score: 20
Accepted
time: 51ms
memory: 10716kb

input:

600 600 500
94408 25551 26106 17499 33966 11993 60914 65730 52906 1455 82794 73795 93412 45890 99934 11687 92321 92137 66466 31214 33613 75980 7050 48011 57463 63723 79159 72353 38799 3627 91506 26571 77219 85065 855 62559 26969 60930 5866 8582 44360 45945 36142 36545 77505 42759 43631 85010 65610 7...

output:

91990 937624827

result:

points 1.0 read (91990 937624827), answer is (91990 937624827)

Test #17:

score: 20
Accepted
time: 52ms
memory: 9976kb

input:

599 597 300
89055 74576 25792 58850 55997 87049 4799 83419 49059 97961 18167 25085 58107 53309 70962 49381 69164 78143 15307 65735 97850 36627 87682 66466 30999 31061 94967 32637 60460 71131 86691 39292 90365 15876 94354 93943 30765 35964 11540 13383 7889 78449 27807 24563 53104 53740 21252 19404 94...

output:

9450 839975421

result:

points 1.0 read (9450 839975421), answer is (9450 839975421)

Test #18:

score: 20
Accepted
time: 8ms
memory: 6828kb

input:

200 200 200
71769 43808 76881 31664 70849 51682 63553 16532 53486 41555 70173 94815 42118 13658 83060 52554 85652 50182 90980 83181 18552 82661 47268 25457 44694 18291 36101 23808 21044 64196 33849 74469 74148 33191 90590 87787 33241 11257 90177 76598 96953 28448 86365 93417 68172 15566 73419 4208 3...

output:

40000 40000

result:

points 1.0 read (40000 40000), answer is (40000 40000)

Subtask #4:

score: 45
Accepted

Test #19:

score: 45
Accepted
time: 1ms
memory: 3744kb

input:

1000 1 1
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
13
...

output:

1 1000

result:

points 1.0 read (1 1000), answer is (1 1000)

Test #20:

score: 45
Accepted
time: 146ms
memory: 27968kb

input:

1500 1500 1500
2057 97289 11714 37286 42177 16754 79528 59246 64175 45623 4520 39496 11777 29875 37503 14157 31214 26265 89910 16164 22254 9643 11083 68021 52923 15438 30801 36202 82991 50951 48515 2156 28524 39879 15191 67450 48448 7429 47735 89030 34952 65783 8838 71730 42366 25873 4974 17173 8855...

output:

996 996

result:

points 1.0 read (996 996), answer is (996 996)

Test #21:

score: 45
Accepted
time: 131ms
memory: 19744kb

input:

1111 1111 1110
78578 53876 79527 19973 6069 60807 57219 24646 85707 38724 18215 36654 79802 31672 45974 31586 9376 94679 80478 3712 20617 59216 46217 62567 48013 45958 57577 53871 8063 48895 44884 59181 83491 85355 36105 62788 35545 58042 99327 45680 60765 30825 30746 73309 56898 54912 88701 82080 2...

output:

100000 400000

result:

points 1.0 read (100000 400000), answer is (100000 400000)

Test #22:

score: 45
Accepted
time: 1058ms
memory: 93708kb

input:

3000 3000 1500
9697 30328 70153 69385 32612 1369 48645 51241 62 49586 6227 85468 84509 45231 94421 17466 52320 87303 95659 50899 63939 14146 2692 46715 55147 17380 54892 54242 8297 12874 33367 28839 18771 84346 60591 89791 6227 34671 90327 34143 50012 39722 75650 28602 49266 90327 49511 14757 41616 ...

output:

999 2250747999

result:

points 1.0 read (999 2250747999), answer is (999 2250747999)

Subtask #5:

score: 15
Accepted

Dependency #1:

100%
Accepted

Dependency #2:

100%
Accepted

Dependency #3:

100%
Accepted

Dependency #4:

100%
Accepted

Test #23:

score: 15
Accepted
time: 257ms
memory: 22008kb

input:

700 2000 500
19104 90057 24721 84760 83772 2411 55841 95428 75829 64873 28761 7914 32525 76305 71726 23061 84426 16881 10571 14703 59712 82273 59535 52563 23385 39576 19803 52499 44790 413 80434 70231 67833 73953 79261 27381 62197 77616 97881 68934 30170 98653 5363 59797 42682 74708 19635 85655 7591...

output:

92074 25008159811

result:

points 1.0 read (92074 25008159811), answer is (92074 25008159811)

Test #24:

score: 15
Accepted
time: 513ms
memory: 36812kb

input:

1000 3000 900
56867 80401 95056 36985 69544 87270 26671 65227 98651 78244 43212 21745 87842 89988 69159 51963 35241 79263 31999 98315 61694 10920 72736 66572 68531 72731 28656 75617 16651 35585 23892 76937 19751 62062 47490 38083 20967 90472 90103 13851 56169 49470 40165 26439 14017 25601 54969 3360...

output:

99982 21085834758

result:

points 1.0 read (99982 21085834758), answer is (99982 21085834758)

Test #25:

score: 15
Accepted
time: 1025ms
memory: 76216kb

input:

2000 3000 1000
60690 87598 43295 5101 24919 99783 62765 48025 8209 29734 35362 48589 77125 47862 51877 25749 50910 60958 51864 86846 44184 14882 91079 83123 53539 45547 56265 19974 93796 25798 23330 48251 84944 78080 72076 14553 26416 10369 36848 63957 1790 44100 49394 22207 26886 31461 43652 54068 ...

output:

100000 200290894737

result:

points 1.0 read (100000 200290894737), answer is (100000 200290894737)

Test #26:

score: 15
Accepted
time: 1275ms
memory: 103692kb

input:

3000 3000 1000
2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99...

output:

1999 8003997999

result:

points 1.0 read (1999 8003997999), answer is (1999 8003997999)

Test #27:

score: 15
Accepted
time: 3015ms
memory: 132820kb

input:

3000 3000 2
40084 5208 57250 48761 3638 90484 74809 94464 15396 29469 14738 75915 32052 33997 70282 87802 49931 52031 40336 38420 49436 66228 43321 67556 81791 49519 66330 14167 48326 37226 45697 34669 7707 22187 23908 31288 2131 39546 10053 8550 97250 60268 52159 95577 6804 54875 89422 62756 23400 ...

output:

4 35975477

result:

points 1.0 read (4 35975477), answer is (4 35975477)

Test #28:

score: 15
Accepted
time: 2763ms
memory: 111648kb

input:

3000 3000 2
9850 9850 9850 9850 65426 9850 65426 65426 9850 9850 65426 65426 9850 9850 65426 9850 65426 65426 9850 65426 65426 9850 65426 9850 65426 65426 9850 9850 9850 9850 9850 65426 65426 9850 65426 9850 9850 65426 65426 65426 65426 9850 9850 65426 65426 9850 9850 65426 9850 9850 65426 9850 9850...

output:

3 16863594

result:

points 1.0 read (3 16863594), answer is (3 16863594)

Test #29:

score: 15
Accepted
time: 1278ms
memory: 68320kb

input:

3000 1500 100
92490 70196 8447 72191 2639 64097 75333 86351 68854 27394 11190 75895 22843 11709 52330 75546 13674 8062 70986 45645 73125 44956 91108 41796 84665 2867 67893 9140 17624 96052 72932 58019 24474 82467 94260 84730 75558 57679 29543 46185 64172 48673 48990 67769 87951 17178 7518 64409 3942...

output:

9614 38676628698

result:

points 1.0 read (9614 38676628698), answer is (9614 38676628698)

Test #30:

score: 15
Accepted
time: 1982ms
memory: 102288kb

input:

3000 3000 500
85200 79572 96585 23455 42328 85200 46915 4233 70751 87863 96585 85200 87863 23455 70751 52079 95981 64304 78663 53593 33710 70751 68026 79572 78663 78663 72306 12730 53593 53593 95981 95918 2692 72306 2692 2692 87863 68026 53593 33710 87863 48535 2692 79572 28393 70751 99251 23455 929...

output:

30 187650030

result:

points 1.0 read (30 187650030), answer is (30 187650030)