• agc016B


    题意

    题目链接

    有$n$个人,每个人有一种颜色,第$i$个人说除了我之外有$a_i$种不同的颜色,问是否存在一组合法解

    Sol

    700分的题就这么神仙了么。。好难啊。。。

    先说结论吧

    设$mx, mn$分别为最大 / 最小值,显然$mx - mn > 1$的时候无解

    接下来分两种情况讨论

    $mx = mn$:这时候每一种颜色要么是互不相同,要么是至少出现两次

    $mx = mn +1$:这时候小的元素一定是独一无二的,大的元素至少出现两次。

    以上结论都可以用反证法证明。


    总结:
    虽然结论证起来不难,但是自己想的话确实是太难受了,因为会有很多干扰你的模型(我最开始的时候还想tarjan缩点来着qwq)。
    自己推了一个多小时也刚刚推除了无解的情况和$mx = mn$的情况,推到最后直接心态爆炸,我甚至都感觉自己的思路有问题,
    因为每个结论要证明都不是很显然,总是感觉自己想复杂了。不过这题确实是好题

    #include<bits/stdc++.h>
    using namespace std;
    const int MAXN = 1e6 + 10, INF = 1e9 + 10;
    inline int read() {
        char c = getchar(); int x = 0, f = 1;
        while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();}
        while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
        return x * f;
    }
    int N, a[MAXN];
    main() {
        N = read();
        for(int i = 1; i <= N; i++) a[i] = read();
        sort(a + 1, a + N + 1);
        int mn = 0, mx = 0, num;
        a[0] = -1;
        for(int i = 1; i <= N; i++) 
            if(a[i] != a[i - 1]) {
                if(!mn) mn = a[i];
                else if(!mx) mx = a[i], num = i - 1;
                else {puts("No"); return 0;}
            }
        if(!mx) {
            if((mn == N - 1) || (mn * 2 <= N)) puts("Yes");
            else puts("No");
        } else {
            if((mx == mn + 1) && (2 * (mx - num) <= N - num) && (mx - num > 0)) puts("Yes");
            else puts("No");
        }
        return 0;
    }
  • 相关阅读:
    Roads in the North
    Labyrinth
    英语写作(二)
    语法长难句笔记
    英语写作(一)
    MySQL笔记(二)
    MySQL笔记(一)
    Mybatis简单使用与配置
    Mybatis映射文件
    什么是serializable接口?
  • 原文地址:https://www.cnblogs.com/zwfymqz/p/9681405.html
Copyright © 2020-2023  润新知