QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#205585#7567. Joining Catsucup-team045#WA 214ms152504kbC++202.1kb2023-10-07 16:38:232023-10-07 16:38:24

Judging History

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

  • [2023-10-07 16:38:24]
  • 评测
  • 测评结果:WA
  • 用时:214ms
  • 内存:152504kb
  • [2023-10-07 16:38:23]
  • 提交

answer

#include<iostream>
#include<cstring>
#include<vector>
#include<queue>
#include<algorithm>
using namespace std;
using LL = long long;
const int maxn = 5005;
vector<pair<short, short> > d[maxn];
short len1[maxn][maxn], len2[maxn][maxn], dp[maxn][maxn];
int w[maxn], s[maxn], id[maxn];
bool v[maxn][maxn];

int main(){

#ifdef LOCAL
    freopen("data.in", "r", stdin);
    freopen("data.out", "w", stdout);
#endif

    cin.tie(0);
    cout.tie(0);
    ios::sync_with_stdio(0);

    int n, k;
    cin >> n >> k;
    for(int i = 1; i <= n; i++) cin >> w[i];
    for(int i = 1; i <= k; i++) 
        cin >> s[i], id[i] = i;
    sort(id + 1, id + k + 1, [&](int a, int b){
        return s[a] < s[b];
    });

    for(int i = 1; i <= n; i++){
        LL sum = 0;
        for(short j = 1, pos = i - 1; j <= k; j++){
            while(pos + 1 <= n && sum + w[pos + 1] <= s[id[j]]){
                sum += w[++pos];
            }
            len1[i][id[j]] = pos - i + 1;
        }
    }
    for(int i = 1; i <= n; i++){
        LL sum = 0;
        for(short j = 1, pos = i + 1; j <= k; j++){
            while(pos - 1 >= 1 && sum + w[pos - 1] <= s[id[j]]){
                sum += w[--pos];
            }
            len2[i][id[j]] = i - pos + 1;
        }
    }

    for(int i = 0; i <= n + 1; i++){
        for(int j = 0; j <= n + 1; j++){
            dp[i][j] = n + 5000;
        }
    }
    dp[0][0] = n + 1;
    // 用了后k个魔法,左端点在j时最小的右端点.
    for(int i = 1; i <= k; i++){
        for(int j = n + 1; j >= 0; j--){
            if (j + 1 <= n + 1){
                dp[i][j] = min(dp[i][j], dp[i][j + 1]);
            }
            int t = len2[j][k - i + 1];
            dp[i][j] = min(dp[i][j], dp[i - 1][j - t]);
            if (dp[i - 1][j] <= n + 1){
                short t1 = len2[dp[i - 1][j] - 1][k - i + 1];
                short tmp = dp[i - 1][j] - t1;
                dp[i][j] = min(dp[i][j], tmp);
            }
            if (j + 2 >= dp[i][j]){
                cout << "Yes" << '\n';
                return 0;
            }
        }
    }
    cout << "No" << '\n';

}

详细

Test #1:

score: 100
Accepted
time: 2ms
memory: 11928kb

input:

5 2
1 1 1 1 1
2 2

output:

Yes

result:

ok answer is YES

Test #2:

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

input:

6 7
3 2 1 1 2 3
2 2 2 2 2 2 2

output:

No

result:

ok answer is NO

Test #3:

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

input:

7 4
1 2 3 4 3 2 1
3 3 3 3

output:

Yes

result:

ok answer is YES

Test #4:

score: 0
Accepted
time: 2ms
memory: 11992kb

input:

5 1
5 4 3 2 1
10

output:

Yes

result:

ok answer is YES

Test #5:

score: 0
Accepted
time: 191ms
memory: 151908kb

input:

5000 5000
775487425 856128884 277783434 903422359 477267301 475103384 297595527 426167697 732858986 408894759 274205836 78265305 841664344 827278645 235744961 539622829 661053351 709331224 497285040 688977639 794889854 890450616 730989757 164925481 519732355 5132018 793806705 617096813 966338860 838...

output:

No

result:

ok answer is NO

Test #6:

score: 0
Accepted
time: 214ms
memory: 151796kb

input:

5000 5000
719129447 937392296 350445117 783330021 802155515 695380072 535475671 613171233 926763173 500405367 828284512 931492995 720877462 919465915 260912626 876806990 884762137 576596567 928561233 974405439 891740632 540536614 879167622 725668608 801467926 601260355 706621299 926987536 994204742 ...

output:

No

result:

ok answer is NO

Test #7:

score: 0
Accepted
time: 201ms
memory: 151804kb

input:

5000 5000
416747559 657602574 449451106 121890071 441124856 144632709 177533820 169507188 105623279 399624204 458468079 481561977 54065647 407303452 627276664 15195167 482406549 98222656 788603298 66301460 298650558 502696353 90244701 498415278 210561025 368288994 77615125 176971936 438514087 804772...

output:

No

result:

ok answer is NO

Test #8:

score: 0
Accepted
time: 25ms
memory: 40684kb

input:

1000 5000
652378395 9226710 369514617 603608037 161741291 783580574 951641399 734721388 223516311 671669592 479702806 414081589 624003108 605424248 896097938 156346340 669596794 597103379 732027711 334398013 586620215 764336953 962550397 952888036 385377097 271706418 466047181 667473147 451787252 34...

output:

Yes

result:

ok answer is YES

Test #9:

score: 0
Accepted
time: 25ms
memory: 40736kb

input:

1000 5000
872227273 712283986 920948311 507385120 918594985 900251115 743516868 670907467 867435817 714475407 652551933 758876839 384367533 880301180 841974114 886109922 903272749 893904997 942686977 997058175 645506447 529091876 716946215 871179658 785614131 908004811 934740746 911599923 901612611 ...

output:

Yes

result:

ok answer is YES

Test #10:

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

input:

1000 5000
101221549 613813024 32283618 57848367 218671138 83846718 546915747 208915568 65619698 104572490 576248450 591458709 44189059 290360076 189086077 191457437 54318230 363455304 196546244 548385206 78485380 617280233 259809060 837752521 143584483 370863408 173419156 323661623 35630081 19426238...

output:

Yes

result:

ok answer is YES

Test #11:

score: 0
Accepted
time: 36ms
memory: 151568kb

input:

5000 1000
384600324 423088534 580011180 18888296 867263085 174486497 579265523 677106522 109080438 243659201 879794825 2734387 317935969 351036145 597636151 139952929 616539853 427107451 467123241 455242831 725282652 898994059 618761912 184726542 957829503 458946364 808393477 865906485 986478739 254...

output:

No

result:

ok answer is NO

Test #12:

score: 0
Accepted
time: 31ms
memory: 151972kb

input:

5000 1000
815377947 795966497 973863440 950044920 825108167 536452850 291112961 631853166 506218010 935798593 775113558 699401829 880383613 914704745 782591416 917669693 708026290 459226993 668663128 910039920 841586352 784964960 888459540 302038322 659730234 805572069 846275367 852703409 775521351 ...

output:

No

result:

ok answer is NO

Test #13:

score: 0
Accepted
time: 41ms
memory: 151828kb

input:

5000 1000
5410336 393698641 500773894 760031044 646621826 839580211 65305975 201814752 180712432 120809208 163818904 82473446 457782197 21160078 17186078 215123683 176709095 456087785 326581971 310290921 168653566 481253103 321257970 84515932 243535065 236109465 60226866 102687808 41257836 127984905...

output:

No

result:

ok answer is NO

Test #14:

score: 0
Accepted
time: 135ms
memory: 151324kb

input:

5000 5000
15093311 329597379 555558975 156779227 62866262 160365196 114014190 248402694 204959438 271068381 399857257 387200774 160688159 271392845 128942838 158633588 10588789 191195688 113594413 649475911 58675835 141948582 145184928 141129342 341594247 628691612 444930099 62485843 137320414 79235...

output:

Yes

result:

ok answer is YES

Test #15:

score: 0
Accepted
time: 209ms
memory: 152504kb

input:

5000 5000
477529887 756849767 625522592 944282843 189025536 780233105 718317626 604366715 944549056 588153327 554003718 861599264 669060580 782705515 966292796 932546478 784316515 903419524 259862391 677467467 214380162 527818442 560973007 946847495 843064055 624959284 944812230 939353394 970748521 ...

output:

No

result:

ok answer is NO

Test #16:

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

input:

1000 5000
325574292 102270354 46216300 32942952 508103079 191913034 609714603 818365900 325049151 156757518 75168501 313902528 82915491 165046883 81073599 194096733 24019640 86346975 61139326 578842271 239372667 581250376 470949194 47949417 121664357 184388214 304047655 135099293 14499837 311933996 ...

output:

Yes

result:

ok answer is YES

Test #17:

score: -100
Wrong Answer
time: 21ms
memory: 40616kb

input:

1000 5000
867019070 634631224 616990385 436336941 698141136 302442938 510047987 433825968 602529602 393200901 816058983 650168038 465885793 838694825 988063665 945400513 617709247 838863094 951999777 922224521 751597816 988527056 878463260 930696432 823011021 936615604 551149310 922193900 339772800 ...

output:

Yes

result:

wrong answer expected NO, found YES