Codeforces Round #626 (Div. 2, based on Moscow Open Olympiad in Informatics)
Codeforces Round #626 (Div. 2, based on Moscow Open Olympiad in Informatics)
A. Even Subset Sum Problem
题意
给出一串数,找到其中的一些数使得他们的和为偶数
题解
水题,找到一个偶数或者两个奇数就好了
代码
#include<iostream>
#include<cstdio>
#include<cstring>
#define def 110
using namespace std;
long a[def];
int main()
{ long _,ans0,ans1,ans2,n,i;
for(scanf("%ld",&_);_;_--){
scanf("%ld",&n);
ans0=ans1=ans2=-1;
for(i=1;i<=n;i++){
scanf("%ld",&a[i]);
if(a[i]%2==0)
ans0=i;
else if(ans1==-1)
ans1=i;
else ans2=i;
}
if(ans0==-1&&(ans1==-1||ans2==-1))
printf("-1\n");
else if(ans0!=-1)
printf("1\n%ld\n",ans0);
else
printf("2\n%ld %ld\n",ans1,ans2);
}
return 0;
}
B. Count Subrectangles
题意
给出\(a\)和\(b\)两个数列,构造一个矩阵\(c\),使得\(c_{i,j}=a_i*b_j\),求矩阵\(c\)中有多少个面积为\(k\)的小矩阵里的值全为1
题解
根据矩阵\(c\)的构造原理可知,每一行相邻元素的连续性由\(b\)决定,每一列的连续性由\(a\)决定,所以可以分别记录下到每个位置到上一个0的长度\(lena\)和\(lenb\),那么当前点为顶点能构成的最大矩阵就是\(lena*lenb\),最后枚举一下小矩阵的边长就好了
代码
#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<set>
#define ll long long
#define lowbit(i) ((i)&-(i))
#define def 40010
using namespace std;
ll sum[def],a[def],b[def];
set<ll>st;
void add(long x,long y)//用树状数组加速在b中的查询
{
for(;x<def;x+=lowbit(x))
sum[x]+=y;
}
ll query(long x)
{ long ans=0;
for(;x;x-=lowbit(x))
ans+=sum[x];
return ans;
}
int main()
{ ll n,m,i,j;
ll ans=0,k;
scanf("%lld%lld%lld",&n,&m,&k);
for(i=1;i<=sqrt(k);i++)
if(k%i==0){
st.insert(i);
st.insert(k/i);
}
for(i=1;i<=n;i++){
scanf("%lld",&a[i]);
if(a[i])
a[i]+=a[i-1];
}
for(i=1;i<=m;i++){
scanf("%lld",&b[i]);
if(b[i]){
b[i]+=b[i-1];
add(b[i],1);
}
}
for(i=1;i<=n;i++)
if(a[i]){
for(auto q:st)
if(a[i]>=k/q&&q<=m)
ans+=query(m)-query(q-1);
}
printf("%lld\n",ans);
return 0;
}
C. Unusual Competitions
题意
给定一个括号序列,每次可以选择一个区间\([l,r]\)来重排,耗时\(r-l+1\),求最少需要多少时间使其变得正常(左右括号完全匹配)
题解
因为时间只跟区间长度有关,跟内容无关,故只要找到不正常的区间来重排就好了
对于一个\(num['(']==num[')']\)的区间,如果其中存在一个点,在这个点上\(num['(']<num[')']\),那么这个区间就是一个不正常的区间
枚举一遍,O(n)解决
代码
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int main()
{ long long n,i,num=0,ans=0,l=0;
bool t=false;
string s;
cin>>n>>s;
for(i=0;i<n;i++){
if(s[i]=='(')
num++;
else
num--;
if(num<0)t=true;
if(!num){
if(t)
ans+=i-l+1;
l=i+1;
t=false;
}
}
if(num)
printf("-1\n");
else
printf("%lld\n",ans);
return 0;
}
Codeforces Round #626 (Div. 2, based on Moscow Open Olympiad in Informatics)的更多相关文章
- Codeforces Round #626 (Div. 2, based on Moscow Open Olympiad in Informatics)部分(A~E)题解
(A) Even Subset Sum Problem 题解:因为n非常非常小,直接暴力枚举所有区间即可. #include<bits/stdc++.h> using namespace ...
- Codeforces Round #680 (Div. 2, based on Moscow Team Olympiad)【ABCD】
比赛链接:https://codeforces.com/contest/1445 A. Array Rearrangment 题意 给定两个大小均为 \(n\) 的升序数组 \(a\) 和 \(b\) ...
- Codeforces Round #680 (Div. 2, based on Moscow Team Olympiad) D. Divide and Sum (思维,数学,逆元)
题意:有一个长度为\(2n\)数组,从中选分别选\(n\)个元素出来组成两个序列\(p\)和\(q\),(\(p\)和\(q\)中只要有任意一个元素在\(a\)的原位置不同,就算一个新的情况),选完后 ...
- Codeforces Round #680 (Div. 2, based on Moscow Team Olympiad) C. Division (数学)
题意:有两个数\(p\)和\(q\),找到一个最大的数\(x\),使得\(p\ mod\ x=0\)并且\(x\ mod\ q\ne 0\). 题解:首先,如果\(p\ mod\ q\ne0\),那么 ...
- Codeforces Round #403 (Div. 2, based on Technocup 2017 Finals)
Codeforces Round #403 (Div. 2, based on Technocup 2017 Finals) 说一点东西: 昨天晚上$9:05$开始太不好了,我在学校学校$9:40$放 ...
- Codeforces Round #500 (Div. 2) [based on EJOI]
Codeforces Round #500 (Div. 2) [based on EJOI] https://codeforces.com/contest/1013 A #include<bit ...
- Codeforces Round #517 (Div. 2, based on Technocup 2019 Elimination Round 2)
Codeforces Round #517 (Div. 2, based on Technocup 2019 Elimination Round 2) #include <bits/stdc++ ...
- Codeforces Round #596 (Div. 2, based on Technocup 2020 Elimination Round 2)
A - Forgetting Things 题意:给 \(a,b\) 两个数字的开头数字(1~9),求使得等式 \(a=b-1\) 成立的一组 \(a,b\) ,无解输出-1. 题解:很显然只有 \( ...
- (AB)Codeforces Round #528 (Div. 2, based on Technocup 2019 Elimination Round
A. Right-Left Cipher time limit per test 1 second memory limit per test 256 megabytes input standard ...
随机推荐
- 学习笔记#Android Studio 从安装到虚拟机启动
1.JDK下载与环境变量配置 (JDK是什么?JDK是 Java 语言的软件开发工具包,主要用于移动设备.嵌入式设备上的java应用程序.JDK是整个java开发的核心,它包含了JAVA的运行环境(J ...
- xshell+xftp将项目部署到远程服务器上
Xshell 简介: Xshell 是一个强大的安全终端模拟软件,它支持SSH1, SSH2, 以及Microsoft Windows 平台的TELNET 协议. Xshell 通过互联网到远程主机的 ...
- 关于 Cantor 集不可数的新观点
第一步操作:将区间 $[0,1]$ 中去掉开区间 $(\frac{1}{3},\frac{2}{3})$ 后,就形成了两个不交闭区间.于是这两个不交闭区间中至少有两个元素,正好是集合 $\{1\}$ ...
- 吴裕雄--天生自然python学习笔记:pandas模块删除 DataFrame 数据
Pandas 通过 drop 函数删除 DataFrarne 数据,语法为: 例如,删除陈聪明(行标题)的成绩: import pandas as pd datas = [[65,92,78,83,7 ...
- blast -m1
当database是10个物种(A.B.C.E.F.G.H.J.I.K)时,进行all vs all 比对结果是: 此时reference是物种A的第一个基因:即用10个物种的genome中的所有基因 ...
- 吴裕雄--天生自然Android开发学习:Android studio 3.5安装详解
3. 建立AVD(安卓虚拟设备) 点击右上角AVD Manager图标,单击按钮Create Virtual Device,选择Nexus 5X,下一步,选择版本9.0,Download,然后Next ...
- Java后台及Jsp前端的简单分页_学习笔记
在你需要导出显示大量列表时,在一页中都显示出来,是不美观页不实用的.在这种时候,就需要设置一个分页来显示你的内容,如百度的分页: 分页分为:前段分页和后端分页 后端分页: 首先我们应该确定,我们要分页 ...
- Markdown快速使用指南
Markdown 是一种轻量级的标记语言,他简洁.高效,目前被越来越多的写作爱好者,撰稿者广泛使用.Markdown的语法十分简单.常用的标记符号也不超过十个,这种相对于更为复杂的 HTML 标记语言 ...
- 吴裕雄--天生自然HTML学习笔记:HTML 元素
HTML 文档由 HTML 元素定义. HTML 元素 开始标签 * 元素内容 结束标签 * <p> 这是一个段落 </p> <a href="default. ...
- 亚马逊Prime会员的杀价,能说明会员+会越来越便宜吗?
前段时间,京东又坑了!京东调整了物流方案--从原来的购物不满49元只需6元运费,调整到购物不满46元运费15元,运费猛涨了9元!原本京东PLUS会员每月有5张免运费券,但在运费涨价后运费券限制在6元, ...