#include <stdio.h>
typedef struct Number
{
int value;
int changes;
} Number;
#define MAX_VALUE 100000
void GetBest(int *count, int total, Number *first, Number *second)
{
*first = (Number){.value = 1, .changes = total - count[1]};
*second = (Number){.value = -1, .changes = total + 1};
for (int i = 2; i <= MAX_VALUE; i += 1) {
Number new_num = {.value = i, .changes = total - count[i]};
if (new_num.changes < first->changes) {
*second = *first;
*first = new_num;
} else if (new_num.changes < second->changes) {
*second = new_num;
}
}
}
int Min(int a, int b) { return a < b ? a : b; }
int count[2][MAX_VALUE + 1];
int main()
{
int n;
scanf("%d", &n);
for (int i = 0; i < n; i += 1) {
int num;
scanf("%d", &num);
count[i % 2][num] += 1;
}
Number even1, even2;
GetBest(count[0], (n + 1) / 2, &even1, &even2);
Number odd1, odd2;
GetBest(count[1], n / 2, &odd1, &odd2);
int res = even1.changes + odd1.changes;
if (even1.value == odd1.value) {
res = Min(even2.changes + odd1.changes,
even1.changes + odd2.changes);
}
printf("%d\n", res);
return 0;
}
./Main.c: In function ‘main’:
./Main.c:34:5: warning: ignoring return value of ‘scanf’, declared with attribute warn_unused_result [-Wunused-result]
scanf("%d", &n);
^
./Main.c:38:9: warning: ignoring return value of ‘scanf’, declared with attribute warn_unused_result [-Wunused-result]
scanf("%d", &num);
^