【jzoj2200】纸牌游戏

题目描述

Bessie 是一头非常喜欢纸牌的奶牛,虽然她没有大拇指,但她对纸牌有近乎痴迷的喜爱。不幸的是,牛群中的其他牛都不是好的对手。他们的水平真的很差。他们总是以一种完全可预测的方式来玩纸牌!尽管如此,Bessie 仍然可以选择如何获胜。
Bessie 和她的朋友Elsie 在玩一个简单的纸牌游戏,她们拿了一付有2n 张卡片的牌,牌上的数字编号为1- 2n ,并将其均分成两份,一份卡片给Bessie 和一份卡片给Elsie。
然后两人开始玩牌,一共进行n 轮, 在每一轮中,Bessie 和Elsie 都打一张卡,谁的牌大就得一分。
神奇的Bessie 可以预测Elsie 打牌顺序,并且尽可能的想赢取胜利。请确定Bessie可以赢得的最大点数。

输入
第一行一个整数N (1≤N≤50,000).
接下来的N 行是Elsie 将每轮连续的比赛中出的牌。请注意,从这些信息很容易确定Bessie 的卡片。

输出
一行给出Bessie 可以得分的最大点数。

样例输入

3
1
6
4

样例输出

2

提示
​贝西手上的牌是2,3,5,她按照2,3,5 的顺序出牌可以获得2 分。


解题思路

先用桶把两个牛(??)的牌求出来
然后用两个指针 i , j i,j i,j枚举两副牌

  • 如果E的牌小于B的牌, E [ i ] < B [ j ] E[i]E[i]<B[j],符合题目要求, i + + , j + + , a n s + + i++,j++,ans++ i++,j++,ans++
  • 如果E的牌小于B的牌,那么大于这张 E [ i ] E[i] E[i] B [ j ] B[j] B[j]在后面, j + + j++ j++

既然 j j j一定要加,那么就直接循环就好了


#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int d[100010],a[50010],b[50010],x,n,num;
int main(){
	freopen("card.in","r",stdin);
	freopen("card.out","w",stdout);
	scanf("%d",&n);
	for(int i=1;i<=n;i++){
		scanf("%d",&x);
		a[i]=x,d[x]=1;//记录桶
	}
	for(int i=1;i<=2*n;i++)
	    if(!d[i])
		   b[++num]=i;//找出另一副牌
	sort(a+1,a+1+n);
	int i=1;
	for(int j=1;j<=n;j++)
		if(a[i]<b[j])
		   i++;
	printf("%d",--i);//i多少就代表匹配了多少 
}

你可能感兴趣的:(暴力/模拟)