zoukankan      html  css  js  c++  java
  • bzoj1034[ZJOI2008]泡泡堂BNB

    bzoj1034[ZJOI2008]泡泡堂BNB

    题意:

    n场比赛,知道自己所有选手的能力值和对方所有选手的能力值,能力值大的一定赢。比赛赢一场得2分,平局得1分,输了不得分。对方随机决定选手顺序,你想知道自己最多能得多少分和最少能得多少分。N≤100000

    题解:

    贪心。设一个高分方和低分方,将两方选手按能力排好序。如果高分方目前最强能赢低分方目前最强,就让他们比赛;如果高分方目前最弱能赢低分方目前最弱,也让他们比赛;否则用高分方最弱的和低分方最强的打。开始先让自己方为高分方,求最大值,再让对方做高分方,本方最小值就是2*n-对方得分。

    代码:

     1 #include <cstdio>
     2 #include <cstring>
     3 #include <algorithm>
     4 #define inc(i,j,k) for(int i=j;i<=k;i++)
     5 #define maxn 200000
     6 using namespace std;
     7 
     8 int a[maxn],b[maxn],n,ans,la,ra,lb,rb;
     9 int main(){
    10     scanf("%d",&n); inc(i,1,n)scanf("%d",&a[i]); inc(i,1,n)scanf("%d",&b[i]); sort(a+1,a+1+n); sort(b+1,b+1+n);
    11     ans=0; la=1; ra=n; lb=1; rb=n;
    12     inc(i,1,n){
    13         if(a[ra]>b[rb])ra--,rb--,ans+=2;else if(a[la]>b[lb])la++,lb++,ans+=2;else ans+=(a[la]==b[rb]),la++,rb--;
    14     }
    15     printf("%d ",ans); swap(a,b);
    16     ans=0; la=1; ra=n; lb=1; rb=n;
    17     inc(i,1,n){
    18         if(a[ra]>b[rb])ra--,rb--,ans+=2;else if(a[la]>b[lb])la++,lb++,ans+=2;else ans+=(a[la]==b[rb]),la++,rb--;
    19     }
    20     printf("%d",2*n-ans); return 0;
    21 }

    20160524

  • 相关阅读:
    arthas-常用命令
    k8s-容器技术-Mount Namespace
    k8s-statefulset介绍
    k8s-yaml配置文件
    k8s-控制器模式
    k8s-pod使用
    k8s-pod简介(半原创)
    k8s-安装我们第一个集群
    k8s-安装
    Corn表达式详解(转)
  • 原文地址:https://www.cnblogs.com/YuanZiming/p/5698455.html
Copyright © 2011-2022 走看看