--- 这里是 cjiaw 的小窝(●'◡'●) ---

正在玩命加载中......

CF_1506_D. Epic Transformation

题目链接:https://codeforces.com/problemset/problem/1506/D


题目大意:

给定一个长度 数组的a,可在数组中任选 两个不同 的数字删除,求如何选可使剩余的数字最少。

例如,如果 ,你可以执行如下操作序列:

  • 选择 ,数组  变为 
  • 选择 ,数组  变为 

贪心:

把每个数字出现的次数看成两个部分,

一部分是出现最多次数 mx,另一部分是 n - mx ,

如果是mx >= n - mx ,说明 出现最多的把其余的消去还有剩余,这种情况下输出 2*mx - n ;

否则,说明其余的把mx消去还有剩余,那么剩下的两两互消除,

如果n 是奇数,那必然剩下一个,输出1,

如果n是偶数,那必然全部消除掉,输出0,


代码:

#include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<vector>
#include<queue>
#include<deque>
#include<stack>
#include<set>
#include<map>
#include<unordered_set>
#include<unordered_map>
#include<bitset>
#include<tuple>
#define inf 72340172838076673
#define int long long
#define endl '\n'
#define F first
#define S second
#define  mst(a,x) memset(a,x,sizeof (a))
using namespace std;
typedef pair<int, int> pii;

const int N = 200086, mod = 998244353;

int n, m;
int a[N];

void solve() {

    cin >> n;
    int mx = 0;
    map<int, int> mp;
    for (int i = 1; i <= n; i++) {
        cin >> a[i];
        mp[a[i]]++;
        mx = max(mx, mp[a[i]]);
    }
    
    if (mx >= n - mx) cout << 2 * mx - n << endl;
    else cout << n % 2 << endl;
}

signed main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr), cout.tie(nullptr);
    
    int T = 1;
    cin >> T;
    while (T--) solve();
    
    return 0;
}

 

posted @ 2025-10-07 16:09  cjiaw  阅读(2)  评论(0)    收藏  举报