Codeforces 496D - Tennis Game
思路:枚举每个t,求出对应的满足条件的s。
代码:
#include<bits/stdc++.h>
using namespace std;
#define ll long long
#define pb push_back
#define mem(a,b) memset((a),(b),sizeof(a))
#define pii pair<int,int>
#define mp make_pair
const int N=1e5+;
int a[N];
int c1[N]={};
int c2[N]={};
pii ans[N]; int main()
{
ios::sync_with_stdio(false);
cin.tie();
int n;
cin>>n;
for(int i=;i<=n;i++)
{
cin>>a[i];
c1[i]=c1[i-];
c2[i]=c2[i-];
if(a[i]==)c1[i]++;
else c2[i]++;
} int s1,s2,last1,last2,c=;
for(int t=;t<=n;t++)
{
s1=s2=last1=last2=;
while(true)
{
int t1=lower_bound(c1+,c1+n+,last1+t)-c1;
int t2=lower_bound(c2+,c2+n+,last2+t)-c2;
if(t1>n&&t2>n)break; int mn=min(t1,t2);
if(mn==t1)s1++;
else s2++; if(mn==n)
{
if(s2>s1&&a[n]==||s1>s2&&a[n]==)
{
ans[c].first=max(s1,s2);
ans[c++].second=t;
}
break;
} last1=c1[mn];//上一局的最后得分
last2=c2[mn];//上一局的最后得分
}
} cout<<c<<endl;
sort(ans,ans+c);
for(int i=;i<c;i++)
cout<<ans[i].first<<' '<<ans[i].second<<endl;
return ;
}
Codeforces 496D - Tennis Game的更多相关文章
- CodeForces 496D Tennis Game (暴力枚举)
		
题意:进行若干场比赛,每次比赛两人对决,赢的人得到1分,输的人不得分,先得到t分的人获胜,开始下场比赛,某个人率先赢下s场比赛时, 游戏结束.现在给出n次对决的记录,问可能的s和t有多少种,并按s递增 ...
 - Tennis Game CodeForces - 496D(唯一分解定理,费马大定理)
		
Tennis Game CodeForces - 496D 通过排列组合解决问题. 首先两组不同素数的乘积,是互不相同的.这应该算是唯一分解定理的逆运用了. 然后是,输入中的素数,任意组合,就是n的因 ...
 - codeforces 735C Tennis Championship(贪心+递推)
		
Tennis Championship 题目链接:http://codeforces.com/problemset/problem/735/C ——每天在线,欢迎留言谈论. 题目大意: 给你一个 n ...
 - codeforces 735C. Tennis Championship(贪心)
		
题目链接 http://codeforces.com/contest/735/problem/C 题意:给你一个数n表示有几个人比赛问最多能赢几局,要求两个比赛的人得分不能相差超过1即得分为2的只能和 ...
 - Codeforces 497B Tennis Game( 枚举+ 二分)
		
B. Tennis Game time limit per test 2 seconds memory limit per test 256 megabytes input standard inpu ...
 - codeforces 497b// Tennis Game// Codeforces Round #283(Div. 1)
		
题意:网球有一方赢t球算一场,先赢s场的获胜.数列arr(长度为n)记录了每场的胜利者,问可能的t和s. 首先,合法的场景必须: 1两方赢的场数不一样多. 2赢多的一方最后一场必须赢. 3最后一场必须 ...
 - Codeforces Round #382 (Div. 2)C. Tennis Championship 动态规划
		
C. Tennis Championship 题目链接 http://codeforces.com/contest/735/problem/C 题面 Famous Brazil city Rio de ...
 - Codeforces Round #397 by Kaspersky Lab and Barcelona Bootcamp (Div. 1 + Div. 2 combined) C. Table Tennis Game 2 水题
		
C. Table Tennis Game 2 题目连接: http://codeforces.com/contest/765/problem/C Description Misha and Vanya ...
 - Educational Codeforces Round 8 A. Tennis Tournament 暴力
		
A. Tennis Tournament 题目连接: http://www.codeforces.com/contest/628/problem/A Description A tennis tour ...
 
随机推荐
- linux 加减符号
			
[root@LocalWeb01 ~]# aa=11[root@LocalWeb01 ~]# bb=22[root@LocalWeb01 ~]# cc=$aa+$bb[root@LocalWeb01 ...
 - linux安装composer及安装yii2
			
wget https://getcomposer.org/download/1.3.2/composer.phar mv composer.phar /usr/local/bin/composer c ...
 - bootstrap3浏览器支持情况
			
Internet Explorer 8 和 9 是被支持的,但是还是有很多CSS3属性和HTML5元素 -- 例如,圆角矩形和投影 -- 是肯定不被支持的.另外,Internet Explorer 8 ...
 - cmd中mysql中文乱码问题
			
以下为自己亲试: 解决cmd中MySQL查询和命令返回的中文乱码问题 1.修改cmd字符集方法 rem 切换到UTF-8 chcp 65001 rem 切换到默认的GBK chcp 936 rem 美 ...
 - mysql存储引擎管理使用
			
mysql采用插件化架构,可以支持不同的存储引擎,比如myisam,innodb.本文简单的介绍mysql存储引擎的管理与使用. 1.查看mysql存储引擎:show engines; 可以看到,my ...
 - Java内存管理(一):深入Java内存区域
			
本文转自:http://www.cnblogs.com/gw811/archive/2012/10/18/2730117.html#undefined 推荐查看原文,原文格式更好一些. 本文引用自:深 ...
 - Linux服务器---apache配置文件
			
Apache配置文件 Apache的配置文件默认路径是“/etc/httpd/conf/httpd.conf”,编辑该文件就可以修改Apache的配置 1.设置网页主目录,参数DocumentRoot ...
 - 让nodepad++编辑时链接能双击打开
			
让nodepad++编辑时链接能双击打开,Notepad++自动把代码或编辑状态里的链接或URL地址转成可点击的链接,当你双击该URL会打开相应的网页地址,不用复制地址到浏览器打开了,非常方便好用. ...
 - 如何使用Unity制作虚拟导览(一)
			
https://www.cnblogs.com/yangyisen/p/5108289.html Unity用来制作游戏已经是目前市场上的一个发展趋势,而且有越来越多的公司与开发者不断的加入,那么Un ...
 - mp4v2 基本知识
			
mp4v2 和mp4的一些基础知识 由于项目需要做mp4文件的合成(264+aac)和mp4文件的解析: MP4文件本身就是一个容器,对于视频来说就是把不同的内容放按照mp4的规则存放而已: 如果完全 ...