QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#93261#6132. Repair the ArtworklamWA 3ms9540kbC++141.5kb2023-03-31 15:57:532023-03-31 15:57:57

Judging History

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

  • [2023-08-10 23:21:45]
  • System Update: QOJ starts to keep a history of the judgings of all the submissions.
  • [2023-03-31 15:57:57]
  • 评测
  • 测评结果:WA
  • 用时:3ms
  • 内存:9540kb
  • [2023-03-31 15:57:53]
  • 提交

answer

#include <bits/stdc++.h>
#define ll long long
using namespace std;
const int maxn = 110LL;
const int mod = 1e9 + 7;
int n,m;
int a[maxn];
int lim[maxn];
ll dp[maxn][10000][2];
ll ppow(int x, int y)
{
    ll temp=1LL;
    while (y)
    {
        if (y&1) temp=temp*x%mod;
        x=x*x%mod;
        y/=2;
    }
    return temp;
}

void xuly()
{
    cin>>n>>m;
    for (int i=1; i<=n; i++) cin>>a[i];
    a[0]=a[n+1]=1;
    dp[0][0][1] = 1LL;
    int mmax = 0;
    lim[0] = 0;
    for (int i=1,last=0; i<=n+1; i++)
    {
        lim[i] = lim[i-1]+(i-last)*(i-last-1)/2;
        for (int j=0; j<=lim[i]; j++) dp[i][j][0] = dp[i][j][1] = 0LL;
        for (int j=last; j<i; j++)
        {
            if (a[j]==0) continue;
            int val = (i-j)*(i-j-1)/2;
            for (int k=0; k<=lim[j]; k++)
                for (int type=0; type<2; type++)
                    if (dp[j][k][type])
                        dp[i][k+val][type^1] = (dp[i][k+val][type^1] + dp[j][k][type])%mod;
        }
        if (a[i]==1) last=i;
    }
    ll ans = 0;
    int sum = 0;
    for (int i=0; i<=n+1; i++) if (a[i]==1) sum++;
    for (int j=0; j<=lim[n+1]; j++)
    {
        ans = (ans + (dp[n+1][j][0] - dp[n+1][j][1] + mod)%mod*ppow(j,m)%mod)%mod;
    }
    if (sum%2==1) ans = (mod-ans)%mod;
    ans=(ans+mod)%mod;
    cout<<ans<<'\n';
}

signed main()
{
    ios_base::sync_with_stdio(false);
    cin.tie(nullptr); cout.tie(nullptr);
    int tt; cin>>tt;
    while (tt--) xuly();
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 0ms
memory: 3320kb

input:

3
2 2
2 0
3 2
2 1 0
3 1
2 1 0

output:

8
3
1

result:

ok 3 number(s): "8 3 1"

Test #2:

score: -100
Wrong Answer
time: 3ms
memory: 9540kb

input:

100
2 1
0 1
2 1
2 1
2 1
1 1
1 6
2
1 14
2
3 12
2 2 2
6 13
2 2 0 2 0 2
7 14
0 0 0 0 2 2 0
5 8
2 2 0 0 0
5 5
2 2 0 0 0
12 3
0 2 0 2 2 0 1 2 2 2 2 0
7 11
2 2 0 1 0 1 0
4 4
2 1 2 2
7 5
1 1 0 0 1 0 0
2 14
2 1
15 17
2 2 1 2 0 0 0 0 2 0 1 0 0 0 0
15 11
1 1 2 0 1 2 0 0 1 0 2 1 1 1 1
15 18
1 0 1 0 2 2 1 2 0 1...

output:

1
1
0
1
1
175715347
834241827
845111185
746182166
650344
2208
537089254
146
7776
1
722973903
123067364
2835372
456663383
884556881
404329489
76275704
369291507
253939639
513270785
581326739
487417783
776148032
308462388
168181473
645032463
414127726
596440363
324262849
946416372
889400976
466366555
...

result:

wrong answer 7th numbers differ - expected: '833406719', found: '834241827'