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 ...
随机推荐
- freebsd安装snmp
pkg_add http://ip地址/pub/FreeBSD/ports/packages/Latest/net-snmp.tbzFetching http://ip地址/pub/FreeBSD/p ...
- Spring Boot :Druid Monitor
忙里偷个闲,在这里分享一下SpringBoot集成Druid实现数据库监控功能,有什么错误欢迎大家指出! 参考文件: Spring实现Druid监控:https://www.cnblogs.com/w ...
- jmeter中通过jdbc方式连接mysql数据库的配置参考
jmeter中通过jdbc方式连接mysql数据库的配置参考: Database URL=jdbc:mysql://ip:port/dbname?useUnicode=true&allowMu ...
- codevs 1262 不要把球传我 2012年CCC加拿大高中生信息学奥赛
时间限制: 1 s 空间限制: 128000 KB 题目等级 : 白银 Silver 题目描述 Description CCC的足球比赛和传统的足球比赛有一点不同, 一次进球当且仅当先后接触到球的 ...
- Eclipse Java类编辑器里出现乱码的解决方案
如图:在Java Class编辑器里出现的这种乱码,非常烦人. 解决方案:Windows->Preference->General->Appearance, 在里面将Theme设置成 ...
- python之路——递归函数
阅读目录 楔子 初识递归 再谈递归 递归函数与三级菜单 递归函数与二分查找算法 楔子 在讲今天的内容之前,我们先来讲一个故事,讲的什么呢?从前有座山,山里有座庙,庙里有个老和尚讲故事,讲的什么呢?从前 ...
- js获取当前日期、前一天、后一天的日期的例子
<script> function addByTransDate(dateParameter, num) { var translateDate = "", dateS ...
- 《3+1团队》第八次团队作业:Alpha冲刺
项目 内容 这个作业属于哪个课程 任课教师博客主页链接 这个作业的要求在哪里 作业链接地址 团队名称 3+1团队 团队博客地址 https://home.cnblogs.com/u/3-1group ...
- Philipp Wagner
本文大部分来自OpenCV官网上的Face Reconition with OpenCV这节内容(http://docs.opencv.org/modules/contrib/doc/facerec/ ...
- java mongodb 增删改查 工具类
package com.jttx.demo; import com.mongodb.*; import com.mongodb.util.JSON; import java.net.Unkno ...