BestCoder Round #32
目前,我们用PM2.5的含量来描述空气质量的好坏。一个城市的PM2.5含量越低,它的空气质量就越好。所以我们经常按照PM2.5的含量从小到大对城市排序。一些时候某个城市的排名可能上升,但是他的PM2.5的含量也上升了。这就意味着他的空气质量并没有改善。所以这样的排序方式是不合理的。为了使得排序合理,我们提出了一个新的排序方法。我们按照两个PM2.5含量测量的差值(第一次-第二次)来对他们按降序排序,如果有重复,按照第二次的测量值升序排序,如果还有重复,按照输入的顺序排序。
多组测试数据(大概100组),每一组测试数据第一行先给出一个整数n,代表有n个城市需要被排序。城市被从0到n−1标号。接下来n行,每一含有两个整数代表每一个城市第一次和第二次被测量的PM2.5值。第i行描述城市i−1的信息。
请处理到文件末尾。
[参数说明]
所有整数都在[1,100]的范围内。
对于每一个数据,输出排好序之后的城市ID。
2
100 1
1 2
3
100 50
3 4
1 2
0 1
0 2 1
思路:三关键词排序
#include<iostream>
#include<cstdio>
#include<algorithm>
#define maxn 1000
char ch[maxn];
using namespace std;
struct T
{
int x;int y;int z;
}a[maxn];
int cmp(T x,T y)
{
return ((x.x>y.x) ||((x.x==y.x && (x.y<y.y))) || (x.x==y.x && x.y==y.y && (x.z<y.z)));
}
int main()
{
int n,x,y;
while(scanf("%d",&n)!=EOF)
{
for(int i=;i<=n;i++)
{
scanf("%d%d",&x,&y);
a[i].x=x-y;
a[i].y=y;
a[i].z=i-;
}
sort(a+,a++n,cmp);
for(int i=;i<n;i++)
{
printf("%d ",a[i].z);
}
printf("%d\n",a[n].z);
}
return ;
}
给定一个数组(a0,a1,a2,⋯an−1)和一个整数K, 请来判断一下是否存在二元组(i,j)(0≤i≤j<n)使得 NP−sum(i,j) 刚好为K。这里NP−sum(i,j)=ai−ai+1+ai+2+⋯+(−1)j−iaj。
多组测试数据。在文件的第一行给出一个T,表示有T组数据。
在接下来的2∗T行里,将会给出每一组数据。
每一组数据占两行,第一行包含n和K。
第二行包含(a0,a1,a2,⋯an−1)以一个空格分开。
[参数说明]
所有输入均为整数。
0<T≤25,1≤n≤1000000,−1000000000≤ai≤1000000000,−1000000000≤K≤1000000000
对于每一个数据,输出占一行,输出格式是Case #id: ans,这儿id是数据编号,从1开始,ans是根据是否找到满足的二元组而定为“Yes.” 或 “No.” (不包含引号)
看样例可以获得更多的信息。
2
1 1
1
2 1
-1 0
Case #1: Yes.
Case #2: No.
如果数据比较多,建议使用快速读入
思路: 比赛的时候认为这个规模带log的都会卡,不然直接map了,然后学了种挂链表的神奇的HASH
#include<cstdio>
#include<iostream>
#include<cstring>
#define maxn 1000009
#define MOD 10000009
using namespace std;
int head[MOD+],nex[maxn],a[maxn];
long long point[maxn],now=,sum[maxn];
long long n,k;
int add(int x,int y)
{
nex[++now]=head[x];
head[x]=now;
point[now]=y;
}
void insert(long long x)
{
long long u=x%MOD;if(u<)u*=-;
for(int i=head[u];i;i=nex[i])
{
if(point[i]==x)return;
}
add(u,x);
}
int find(long long x)
{
long long u=x%MOD;if(u<)u*=-;
for(int i=head[u];i;i=nex[i])
{
if(point[i]==x)return ;
}
return ;
}
long long read()
{
long long x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
int main()
{
int t,cas=;
t=read();
while(t--)
{
n=read();k=read();
for(int i=;i<=n;i++)a[n-i+]=read();
for(int i=;i<=n;i++)
{
if(i&)
{
sum[i]=sum[i-]+a[i];
}else sum[i]=sum[i-]-a[i];
}
int flag=;
insert();
for(int i=;i<=n;i++)
{
if(i&)
{
if(find(sum[i]-k)){flag=;break;}
}
else if(find(sum[i]+k)){flag=;break;}
insert(sum[i]);
}
printf("Case #%d: ",++cas);
if(flag)printf("Yes.\n");
else printf("No.\n");
memset(head,,sizeof(head));
now=;
}
return ;
}
HDU 5184 Brackets
我们给出下列递归的合法括号序列的定义:
● 空序列是合法括号序列
● 如果s是一个合法括号序列,那么(s)也是合法括号序列
● 如果a和b是合法括号序列,那么ab也是合法括号序列
● 没有其它情况是合法括号序列 比如下列括号序列是合法括号序列
(), (()), ()(), ()(())
下列括号序列则不是
(, ), )(, ((), ((() 现在,我们要构造长度为n的合法括号序列,前面的一些括号已经给出,问可以构造出多少合法序列。
多组测试数据(大概2000),每一组数据占两行。
第一行给出一个整数n。
第二行给出一个字符串代表前面已经确定的几个括号。
请处理到文件末尾。 [参数约定]
1≤n≤1000000
字符串只包含’(’和’)’,长度大于0并且不超过n.
对于每一个数据,在一行中输出答案对1000000007取余的结果。
4
()
4
(
6
()
1
2
2
对于第二组数据他有两种可能,他们是(()) 和()().
对于第三种数据,两种可能是()()() 和()(()).
思路:这题建模有点醉啊 问题可以变成,从(0,0)到(n/2-a,n/2-b)且不越过y=x 这条线的方案数,然后从(0,0)到(p,q)且不经过y=x的方案数是C(p,p+q)-C(p-1,p+q)
#include<iostream>
#include<cstring>
#include<cstdio>
#define MOD 1000000007
#define LLD "%lld"
#define maxn 1000009
#define ll long long
using namespace std;
char ch[maxn];
ll fac[maxn],inv[maxn];
ll qpow(ll a,ll n)
{
ll ret=;
for(;n;n>>=)
{
if(n&)ret=(ret*a)%MOD;
a=(a*a)%MOD;
}
return ret;
}
ll C(ll n,ll m)
{
if(m==)return ;
ll u=fac[n],v = inv[n-m],w=inv[m];
return (((fac[n]*inv[n-m])%MOD)*inv[m])%MOD;
}
int main()
{
ll n;
fac[]=;
for(int i=;i<=maxn-;i++)
{
fac[i]=(fac[i-]*(long long)i)%MOD;
inv[i]=qpow(fac[i],MOD-)%MOD;
}
while(scanf( LLD "%s",&n,ch+)!=EOF)
{
if(n&)
{
puts("");
continue;
}
ll len=strlen(ch+);
ll lef=,flag=,a=,b=;
for(int i=;i<=len;i++)
{
if(ch[i]=='(')a++;else b++;
if(ch[i]=='(')lef++;
else if(lef!=)lef--;
else flag=;
}
if(flag){puts("");continue;} ll p=( n >> ) - a,q= ( n >> ) - b;
if(p< ||q<){puts("");continue;}
if(p>q)swap(p,q);
ll u = C(p + q , p), v = C(p + q ,p - );
printf(LLD "\n" , (C(p + q , p) - C(p + q,p - ) + MOD ) % MOD);
}
return ;
}
BestCoder Round #32的更多相关文章
- DP BestCoder Round #50 (div.2) 1003 The mook jong
题目传送门 /* DP:这题赤裸裸的dp,dp[i][1/0]表示第i块板放木桩和不放木桩的方案数.状态转移方程: dp[i][1] = dp[i-3][1] + dp[i-3][0] + 1; dp ...
- BestCoder Round #89 02单调队列优化dp
1.BestCoder Round #89 2.总结:4个题,只能做A.B,全都靠hack上分.. 01 HDU 5944 水 1.题意:一个字符串,求有多少组字符y,r,x的下标能组成等比数列 ...
- BestCoder Round #90 //div all 大混战 一题滚粗 阶梯博弈,树状数组,高斯消元
BestCoder Round #90 本次至少暴露出三个知识点爆炸.... A. zz题 按题意copy Init函数 然后统计就ok B. 博弈 题 不懂 推了半天的SG..... 结果这 ...
- bestcoder Round #7 前三题题解
BestCoder Round #7 Start Time : 2014-08-31 19:00:00 End Time : 2014-08-31 21:00:00Contest Type : ...
- Bestcoder round #65 && hdu 5593 ZYB's Tree 树形dp
Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total Submissio ...
- Bestcoder round #65 && hdu 5592 ZYB's Premutation 线段树
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others)Total Submissio ...
- 暴力+降复杂度 BestCoder Round #39 1002 Mutiple
题目传送门 /* 设一个b[]来保存每一个a[]的质因数的id,从后往前每一次更新质因数的id, 若没有,默认加0,nlogn复杂度: 我用暴力竟然水过去了:) */ #include <cst ...
- 贪心 BestCoder Round #39 1001 Delete
题目传送门 /* 贪心水题:找出出现次数>1的次数和res,如果要减去的比res小,那么总的不同的数字tot不会少: 否则再在tot里减去多余的即为答案 用set容器也可以做,思路一样 */ # ...
- BestCoder Round #88
传送门:BestCoder Round #88 分析: A题统计字符串中连续字串全为q的个数,预处理以下或加个cnt就好了: 代码: #include <cstdio> #include ...
随机推荐
- MySQL的information_schema的介绍(转)
转自:http://www.cnblogs.com/hzhida/archive/2012/08/08/2628826.html, 大家在安装或使用MYSQL时,会发现除了自己安装的数据库以外,还有一 ...
- 忘记Centos7.2下root用户密码后的处理方式
1)重启系统 重新启动系统后并按f2键,进入如下的界面,再按e键. 2)修改启动内核代码 在代码的linux16行中,将ro rhgb的ro修改为rw init=/sysroot/bin/sh. 3) ...
- 融云参加RTC实时互联网大会 现场集成IM SDK
9月21至22日,由全球实时云服务商声网Agora.io主办的RTC2017实时互联网大会在北京万豪酒店成功举办.作为亚洲最权威的RTC实时通信行业技术盛会,会议吸引了来自全球上千名开发者参加,Goo ...
- 远程文件拷贝(fastcopy为例)
远程地址格式如下:\\IP地址\磁盘符号$\文件夹名称(如:127.0.0.1\\c$\\image)拷贝了image文件夹下面的所有文件,但是如果远程机器有密码的话要先在本机先输入远程的目标地址然后 ...
- webpack之postcss集成
项目 为了 兼容各个浏览器,需要加各种 c3前缀,如果手动的加肯定 相对比较麻烦,但是现在有webpack,gulp之类的 工具可以自动给我们加上,可以说效率上加速不少.如果 配置中 做个happyp ...
- 在tomcat中配置连接池
在tomcat的conf/Catalina/localhost目录下配置项目路径,tomcat启动是会直接根据配置去加载项目. 虽然配置就一句话,但经常忘,今天记下来. 如果你的项目成名是:mypro ...
- Java中的线程--多线程面试题
到这里,基本上线程的并发中的知识点都是学到了,到了最后,还有三道面试题,从面试题中学习更加的加深一下,多线程中的知识点,如何在实际的问题中来解决多线程的问题,可以更好的从实际出发 一.面试题1 面试题 ...
- iOS开发遇见的坑之二:工程文件中插件和自身工程命名冲突
在升级cocoapod后,我重新管理了一下工程,其实也就是把各个类分类进行管理 类似于这样 然后编译就发现不能运行 1.其中一个错误是工程文件缺失,根据提示添加进来进行 2.有一个是pch的相对路径变 ...
- C# 使用Epplus导出Excel [1]:导出固定列数据
C# 使用Epplus导出Excel [1]:导出固定列数据 C# 使用Epplus导出Excel [2]:导出动态列数据 C# 使用Epplus导出Excel [3]:合并列连续相同数据 C# 使用 ...
- python 有4个数字1234,能组成多少个互不相同且无重复的三位数数字。
def output(): count = 0 for i in range(1,5): for j in range(1, 5): for k in range(1, 5): if i==j or ...