QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#534085#8340. 3 Sumtraining_233#WA 42ms8336kbC++143.5kb2024-08-26 20:30:172024-08-26 20:30:18

Judging History

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

  • [2024-09-20 10:20:30]
  • hack成功,自动添加数据
  • (/hack/848)
  • [2024-08-26 20:30:18]
  • 评测
  • 测评结果:WA
  • 用时:42ms
  • 内存:8336kb
  • [2024-08-26 20:30:17]
  • 提交

answer

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<string>
#include<map>
#include<random>
#include<chrono>
using namespace std;
const long long mod=1e18;
int n,m,ans,cnt;
long long base;
string s;
mt19937 rnd(chrono::steady_clock::now().time_since_epoch().count());
struct num
{
    int len;
    long long a[1201];
    num()
    {
        len=0;
    }
    inline void init(string &s)
    {
        reverse(s.begin(),s.end());
        while(s.length()%18)
            s.push_back('0');
        len=s.length()/18;
        for(int i=len;i>=1;--i)
            for(int j=1;j<=18;++j)
            {
                a[i]=a[i]*10+s.back()-'0';
                s.pop_back();
            }
    }
    bool operator <(const num &other) const
    {
        if(len^other.len)
            return len<other.len;
        for(int i=len;i>=1;--i)
            if(a[i]^other.a[i])
                return a[i]<other.a[i];
        return 0;
    }
    bool operator ==(const num &other) const
    {
        if(len^other.len)
            return 0;
        for(int i=len;i>=1;--i)
            if(a[i]^other.a[i])
                return 0;
        return 1;
    }
    int operator %(const int &mod) const
    {
        int d=0;
        for(int i=len;i>=1;--i)
            d=(base%mod*d+a[i])%mod;
        return d;
    }
}a[501],tmp,M;
int w[501];
inline num operator +(const num &x,const num &y)
{
    num res;
    res.len=max(x.len,y.len);
    long long d=0;
    for(int i=1;i<=res.len;++i)
    {
        res.a[i]=d;
        if(res.len<=x.len)
            res.a[i]+=x.a[i];
        if(res.len<=y.len)
            res.a[i]+=y.a[i];
        d=res.a[i]/mod;
        res.a[i]%=mod;
    }
    while(d)
    {
        res.a[++res.len]=d;
        d=res.a[res.len]/mod;
        res.a[res.len]%=mod;
    }
    return res;
}
inline num operator -(const num &x,const num &y)
{
    num res;
    res.len=x.len;
    long long d=0;
    for(int i=1;i<=res.len;++i)
    {
        res.a[i]=x.a[i]-d;
        if(i<=y.len)
            res.a[i]-=y.a[i];
        d=0;
        if(res.a[i]<0)
        {
            res.a[i]+=mod;
            d=mod;
        }
    }
    while(res.len&&!res.a[res.len])
        --res.len;
    return res;
}
inline num solve(num x)
{
    while(!(x<M))
    {
        if(x==M)
        {
            x.len=0;
            return x;
        }
        tmp.len=x.len-M.len+1;
        for(int i=M.len;i<=x.len;++i)
            tmp.a[i-M.len+1]=x.a[i]/base+x.a[i+1]%base*(mod/base);
        x.a[M.len]%=base;
        while(!tmp.a[tmp.len])
            --tmp.len;
        x.len=M.len;
        x=tmp+x;
    }
    while(x.len&&!x.a[x.len])
        --x.len;
    return x;
}
inline void solve()
{
    int now=rnd()%(100000000)+1,val1=M%now,val2=(M+M)%now;
    for(int i=1;i<=n;++i)
        w[i]=a[i]%now;
    for(int i=1;i<=n;++i)
        for(int j=i;j<=n;++j)
            for(int k=j;k<=n;++k)
                ans+=(w[i]+w[j]+w[k])%now==0||(w[i]+w[j]+w[k])%now==val1||(w[i]+w[j]+w[k])==val2;
}
inline void init()
{
    ios::sync_with_stdio(0);
    cin.tie(0);
}
int main()
{
    init();
    cin>>n>>m;
    cnt=m%18;
    base=1;
    for(int i=1;i<=cnt;++i)
        base*=10;
    for(int i=1;i<=m;++i)
        s.push_back('9');
    M.init(s);
    for(int i=1;i<=n;++i)
    {
        cin>>s;
        a[i].init(s);
        a[i]=solve(a[i]);
    }
    solve();
    cout<<ans<<'\n';
    cout.flush();
    return 0;
}

詳細信息

Test #1:

score: 100
Accepted
time: 1ms
memory: 6972kb

input:

4 1
0
1
10
17

output:

3

result:

ok 1 number(s): "3"

Test #2:

score: -100
Wrong Answer
time: 42ms
memory: 8336kb

input:

500 859
7118711592236878297922359501613604144948355616986970837340677671376753603836852811886591300370143151943368529129749813118476151865844255212534355441611481420938483178075143062691345257288242460282715389758789648541099090735875617822348551942134616963557723055980260082230902505269975518146286...

output:

3

result:

wrong answer 1st numbers differ - expected: '0', found: '3'