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 ...
随机推荐
- 介绍hadoop的好文章
http://www.centoscn.com/image-text/install/2014/1121/4158.html http://www.cnblogs.com/xia520pi/categ ...
- MySQL字符集和排序介绍
客服端字符集: character_set_client utf8mb4连接字符集: character_set_connection utf8mb4数据库字符集: character_set_dat ...
- [论文笔记] A Practical Architecture of Cloudification of Legacy Applications (2011, SERVICES)
Dunhui Yu, Jian Wang, Bo Hu, Jianxiao Liu, Xiuwei Zhang, Keqing He, and Liang-Jie Zhang. 2011. A Pra ...
- (二)maven之项目结构
我们可以看一下Maven项目的大致结构: 项目结构: src/main/java:java源代码文件目录. src/main/resources:资源库,会自动赋值到classes目录里,像 ...
- iOS面试题 第一天
今天上午,下午分别面试了两家公司.上午是一家互联网公司,气氛还比较好,是我比较喜欢的.技术这块是直接机试,主要是给了些BUG让我修复,整个过程还算顺利.下午去了一家大型的证券公司.整理技术问题如下: ...
- 阿里云apt-get安装包时Err:2 http://mirrors.cloud.aliyuncs.com/ubuntu xenial-security/main amd64 git amd64 1:2.7.4-0ubuntu1.2 404 Not Found
新部署的云服务器出现如下错误: root@iZj6cbjalvhsw0fhndmm5xZ:~# apt-get install git Reading package lists... Done Bu ...
- CSAPP lab1 datalab-handout
这是一个关于机器级的整数.浮点数表示和位运算的实验.要求用给定的操作符.尽可能少的操作数去实现对应的函数功能. 完整的实验包:链接: https://pan.baidu.com/s/1xUBi3XDl ...
- valgrind测试程序内存泄漏问题
1.用wincap将valgrind放入系统任意路径下,解压 2. 登录主机后台在需要测试程序的路径下运行此行命令: /opt/valgrind/bin/valgrind ./itb(例) 3. 跑 ...
- 【转】Python 访问 HDFS
1.前言 hdfs , Hadoop Distributed File System.Hadoop的分布式文件系统,安全行和扩展性没得说. 访问HDFS的方式有以下几种: 命令行方式:FS Shell ...
- C语言中最常用标准库函数
标准头文件包括: <asset.h> <ctype.h> <errno.h> <float.h> <limits ...