C. Doremy‘s City Construction(二分图问题)

思路:把集合划分成两部分,一部分中每个数都比另一部分小,这两部分连成一个完全二分图,这种情况是最优的,还需要特判所有数都相等的情况.

代码:

cpp 复制代码
void solve(){
    int n;
    cin >> n;
    vector<int>a(n + 1);
    for(int i = 1;i <= n;i ++)
        cin >> a[i];
    sort(a.begin(),a.end());
    if(a[1] == a[n]){
        cout << n/2 << endl;
        return;
    }
    int ans =0;
    for(int i = 1;i <= n;i ++){
        int j = i;
        while(j + 1 <= n && a[j + 1] == a[i])j ++;
        ans = max(ans ,j * (n - j));
        i = j;
    }
    cout << ans << endl;
}
相关推荐
x_xbx7 小时前
LeetCode:102. 二叉树的层序遍历
算法·leetcode
2401_889884668 小时前
嵌入式C++测试框架
开发语言·c++·算法
DREW_Smile8 小时前
字符函数和字符串函数2
c语言·开发语言
月明长歌8 小时前
【码道初阶-Hot100】LeetCode 128. 最长连续序列:从排序双指针扫描到 HashSet,一文讲透为什么 O(n) 解法要用哈希
算法·leetcode·哈希算法
Z9fish8 小时前
C语言算法专题总结(一)排序
c语言·算法·排序算法
Felven8 小时前
B. Roof Construction
c语言
美式请加冰8 小时前
模拟的介绍和使用
java·开发语言·算法
无限进步_8 小时前
深入解析vector:一个完整的C++动态数组实现
c语言·开发语言·c++·windows·git·github·visual studio
云泽8088 小时前
蓝桥杯算法精讲:贪心算法之区间问题深度剖析
算法·贪心算法·蓝桥杯
tankeven8 小时前
HJ129 小红的双生数
c++·算法