首页 > 其他 > 详细

Codeforces Round #277.5 (Div. 2) b

时间:2014-11-19 02:23:31      阅读:285      评论:0      收藏:0      [点我收藏+]
/**
 * @brief Codeforces Round #277.5 (Div. 2) b
 * @file b.c
 * @author 面码
 * @created 2014/11/18 17:22
 * @edited  2014/11/18 17:22
 * @type greedy
 *
 */
#include <stdio.h>

#define MAXN 110

#define max(a, b)  ((a) > (b) ? (a) : (b))
#define min(a, b)  ((a) > (b) ? (b) : (a)) 
#define abs(a)     ((a) >  0  ? (a) : (0 - (a)))

int n, m;
int girls[MAXN];
int boys[MAXN];
int tot;

int main()
{
    int i, val;
#ifdef DEBUG
    freopen("./in",  "r", stdin);
    freopen("./out", "w", stdout);
#endif
    scanf("%d", &n);
    for(i = 0; i < n; i++){
        scanf("%d", &val);
        ++boys[val];
    }

    scanf("%d", &m);
    for(i = 0; i < m; i++){
        scanf("%d", &val);
        ++girls[val];
    }

    /*greedy here, we must see the problem from boys or girls, this is very important*/
    tot = 0;
    for(i = 1; i <= 100; i++){
        val = min(boys[i], girls[i - 1]);
        tot             += val;
        boys[i]         -= val;
        girls[i - 1]    -= val;

        val = min(boys[i], girls[i]);
        tot             += val;
        boys[i]         -= val;
        girls[i]        -= val;
    
        val = min(boys[i], girls[i + 1]);
        tot             += val;
        boys[i]         -= val;
        girls[i + 1]    -= val;
    }

    printf("%d\n", tot);
    return 0;
}


Codeforces Round #277.5 (Div. 2) b

原文:http://my.oschina.net/u/572632/blog/346092

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!