目录

官方题解

C

这道题教会了我怎样正确统计众数和第二众数...........
我之前的方法是错的

#include <bits/stdc++.h>
using namespace std;
 
 
#define rep(i, _st, _ed) for(register int i = (_st); i <= (_ed); i++)
 
int n, buc[2][100009]; 
 
int main() {
//  freopen("top2_3.txt", "r", stdin); 
    cin >> n;
    rep(i, 1, n) {
        int tmp; cin >> tmp;
        buc[i%2][tmp]++;
    }
    int mx[2][2], num[2]; memset(mx, 0, sizeof mx); memset(num, 0, sizeof num);
    rep(j, 0, 1)    rep(i, 0, 100000){
        if(mx[j][0] < buc[j][i]) {
            mx[j][1] = mx[j][0];
            mx[j][0] = buc[j][i];
            num[j] = i;
        } else if(mx[j][1] < buc[j][i]){
            mx[j][1] =  buc[j][i];
        }
    }
    /*
        error:
        if(mx[j][0] <= buc[j][i]) {
            mx[j][1] = mx[j][0];
            mx[j][0] = buc[j][i];
            num[j] = i;
        }
        因为只有当更新最大值时, 才会更新次大值...
        其实应该单独考虑
        hack:
        155 166 159
        这样这个bug程序会得到mx1 = 166, mx2 = 155的错误结果 
    */
    int chg = 0;
    if(num[0] != num[1]) chg =  mx[0][0] + mx[1][0];
    else {
        chg = max(mx[0][0] + mx[1][1] , mx[1][0] + mx[0][1]);
    }
//    printf("%d %d\n %d %d\n", mx[0][0], mx[0][1], mx[1][0], mx[1][1]);
    cout << n-chg <<endl;
}
优质内容筛选与推荐>>
1、Jboss无法通过IP地址访问,只能用localhost\127.0.0.1访问
2、灰色界面闪
3、深度优先和广度优先
4、java:easyui(重点示例)
5、委托与事件的使用


长按二维码向我转账

受苹果公司新规定影响,微信 iOS 版的赞赏功能被关闭,可通过二维码转账支持公众号。

    阅读
    好看
    已推荐到看一看
    你的朋友可以在“发现”-“看一看”看到你认为好看的文章。
    已取消,“好看”想法已同步删除
    已推荐到看一看 和朋友分享想法
    最多200字,当前共 发送

    已发送

    朋友将在看一看看到

    确定
    分享你的想法...
    取消

    分享想法到看一看

    确定
    最多200字,当前共

    发送中

    网络异常,请稍后重试

    微信扫一扫
    关注该公众号





    联系我们

    欢迎来到TinyMind。

    关于TinyMind的内容或商务合作、网站建议,举报不良信息等均可联系我们。

    TinyMind客服邮箱:support@tinymind.net.cn