zoukankan      html  css  js  c++  java
  • ARC 103

    官方题解

    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
     %d %d
    ", mx[0][0], mx[0][1], mx[1][0], mx[1][1]);
        cout << n-chg <<endl;
    }
    
  • 相关阅读:
    d
    今天刚注册,测试下
    关于Hadoop的简单介绍
    leveldb 阅读笔记 (2) 简易测试框架
    leveldb 阅读笔记(1) 内存分配器 Arena
    数论
    伴随网站
    convenience website
    大佬独特的骗分技巧
    动态规划
  • 原文地址:https://www.cnblogs.com/Eroad/p/9748671.html
Copyright © 2011-2022 走看看