QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#734872#8760. 不等式swan416#WA 0ms4120kbC++202.6kb2024-11-11 15:37:012024-11-11 15:37:06

Judging History

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

  • [2024-11-11 15:37:06]
  • 评测
  • 测评结果:WA
  • 用时:0ms
  • 内存:4120kb
  • [2024-11-11 15:37:01]
  • 提交

answer

#include <bits/stdc++.h>
#define maxOf(a) *max_element(a.begin(),a.end())
using namespace std;
typedef long long ll;
typedef double db;
typedef pair<int,int> pii;
typedef pair<ll,ll> pll;

void solve()
{
    int n,m;
    scanf("%d%d",&n,&m);
    vector<int> out[n+1],in[n+1];
    int out_cnt[n+1],in_cnt[n+1];
    memset(out_cnt,0,sizeof(out_cnt));
    memset(in_cnt,0,sizeof(in_cnt));
    vector<tuple<int,int,int>> query;
    map<pii,int> mp;
    for(int i=0;i<m;i++)
    {
        int x,y,z;
        scanf("%d%d%d",&x,&y,&z);
        query.push_back({x,y,z});
        if(mp[{x,y}]==0)
        {
            mp[{x,y}]=1;
            out[x].push_back(y);
            out_cnt[x]++;
            in[y].push_back(x);
            in_cnt[y]++;
        }
        if(mp[{x,z}]==0)
        {
            mp[{x,z}]=1;
            out[x].push_back(z);
            out_cnt[x]++;
            in[z].push_back(x);
            in_cnt[z]++;
        }
    }
    queue<int> q;
    for(int i=1;i<=n;i++)
    {
        if(in_cnt[i]==0)
        {
            q.push(i);
        }
    }
    while(q.size())
    {
        int x=q.front();
        q.pop();
        for(int y:out[x])
        {
            in_cnt[y]--;
            if(in_cnt[y]==0)
            {
                q.push(y);
            }
        }
    }
    for(int i=1;i<=n;i++)
    {
        if(in_cnt[i]>0)
        {
            printf("-1\n");
            return ;
        }
    }
    auto cmp=[&](tuple <int,int,int> a,tuple <int,int,int> b)
    {
        tuple<int,int,int> x,y;
        x={out_cnt[get<0>(a)],out_cnt[get<1>(a)],out_cnt[get<2>(a)]};
        y={out_cnt[get<0>(b)],out_cnt[get<1>(b)],out_cnt[get<2>(b)]};
        return x<y;
    };
    sort(query.begin(),query.end(),cmp);
    ll value[n+1];
    memset(value,0,sizeof(value));
    for(int i=1;i<=n;i++)
    {
        if(out_cnt[i]==0)
            value[i]=1;
    }
    for(int i=0;i<m;i++)
    {
        int x,y,z;
//        printf("%d %d %d\n",get<0>(query[i]),get<1>(query[i]),get<2>(query[i]));
        tie(x,y,z)=query[i];
        value[x]=max(value[x],value[y]+value[z]);
//        printf("so I change the value of %d to %lld\n",x,value[x]);
    }
    ll ans=0;
    for(int i=1;i<=n;i++)
    {
//        printf("%lld ",value[i]);
        ans+=value[i];
    }
//    printf("\n");
    if(ans>1e9)
    {
        printf("-1\n");
    }
    else
    {
        printf("%lld\n",ans);
    }
}

int main()
{
    int T=1;
    //scanf("%d",&T);
    while(T--)
    {
        solve();
    }
    return 0;
}

详细

Test #1:

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

input:

3 1
1 2 2

output:

4

result:

ok 1 number(s): "4"

Test #2:

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

input:

3 1
1 2 3

output:

4

result:

ok 1 number(s): "4"

Test #3:

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

input:

3 1
1 2 2

output:

4

result:

ok 1 number(s): "4"

Test #4:

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

input:

3 1
1 2 2

output:

4

result:

ok 1 number(s): "4"

Test #5:

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

input:

3 1
1 2 2

output:

4

result:

ok 1 number(s): "4"

Test #6:

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

input:

5 1
1 2 2

output:

6

result:

ok 1 number(s): "6"

Test #7:

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

input:

5 1
1 2 2

output:

6

result:

ok 1 number(s): "6"

Test #8:

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

input:

5 1
1 2 2

output:

6

result:

ok 1 number(s): "6"

Test #9:

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

input:

5 1
1 2 3

output:

6

result:

ok 1 number(s): "6"

Test #10:

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

input:

5 2
1 2 3
2 3 4

output:

8

result:

ok 1 number(s): "8"

Test #11:

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

input:

10 1
1 2 3

output:

11

result:

ok 1 number(s): "11"

Test #12:

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

input:

10 1
1 2 2

output:

11

result:

ok 1 number(s): "11"

Test #13:

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

input:

10 2
1 2 3
2 3 4

output:

13

result:

ok 1 number(s): "13"

Test #14:

score: -100
Wrong Answer
time: 0ms
memory: 3840kb

input:

10 2
1 2 2
2 3 4

output:

10

result:

wrong answer 1st numbers differ - expected: '14', found: '10'