社区讨论

80分,错了一个点,马蜂友好

P14575坤班参与者 4已保存回复 5

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
5 条
当前快照
1 份
快照标识符
@micr1ssd
此快照首次捕获于
2025/11/24 14:11
3 个月前
此快照最后确认于
2025/11/24 16:27
3 个月前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
int al[500005][2];
int main()
{
    int n,m;
    cin>>n>>m;
    for(int i=1;i<=n;i++)al[i][0]=al[i][1]=0;
    for(int i=1;i<=n;i++)
    {
        int a,b,c;
        cin>>a>>b>>c;
        al[a][0]+=b;
        if(c)al[a][1]++;
    }
    for(int i=n;i>=-1;i--)
    {
        bool ifc=true;
        int sum1=0;
        for(int j=1;j<=m;j++)
        {
            if(al[j][0]<i)
            {
                ifc=false;
                break;
            }
            sum1+=min(al[j][0]-i,al[j][1]);
        }
        if(!ifc)continue;
        int sum=0;
        for(int j=1;j<=m;j++)sum+=al[j][1];
        if(i>sum)continue;
        if(i>sum1)continue;
        cout<<i;
        return 0;
    }
    cout<<0;
}

回复

5 条回复,欢迎继续交流。

正在加载回复...