1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
#include <cstdio>
#include <cstdlib>

static int qcmp(const void *a, const void *b)
{
    if (*(const int *)a < *(const int *)b)
        return 1;
    if (*(const int *)a > *(const int *)b)
        return -1;
    return 0;
}

int main(void) {
    int i, n, *c, cnt = 0, ret = 0;

    scanf("%d", &n);

    c = (int *)calloc(n + 1, sizeof(*c));

    for (i = 0; i < n; i++) {
        int a;
        scanf("%d", &a);
        c[a]++;
    }

    qsort(c, n, sizeof(*c), qcmp);

    for (i = 0; i < n; i++) {
        cnt += c[i] * 2 - 1;
        ret++;

        if (cnt >= n)
            break;
    }

    printf("%d\n", ret);
    return 0;
}