CF-938(C-E)
CF-938
C
没啥好分析的,就记录一下我因为没有清空s[n+1]、上取整写成了下取整卡了一个多小时(╬▔皿▔)╯
const int N=2e5+5;
int a[N],p[N],s[N];
void solve(){
int n,k;cin>>n>>k;
int sum=0;
rep(i,1,n){
cin>>a[i];
p[i]=p[i-1]+a[i];
}
if(p[n]<=k){
cout<<n<<endl;
return;
}
s[n+1]=0;//
per(i,n,1){
s[i]=s[i+1]+a[i];
}
int ans=0;
int l=0,r=n,mid;
while(r-l>1){
mid=l+r>>1;
if(p[mid]<(k+1)/2) l=mid;
else r=mid;
}
//r为第一个p[i]>=(k+1)/2的下标
if(p[r]>(k+1)/2) ans+=r-1;
else if(p[r]==(k+1)/2) ans+=r;
l=1,r=n+1;
while(r-l>1){
mid=l+r>>1;
if(s[mid]<(k+1)/2) r=mid;
else l=mid;
}
//l为第一个p[i]>=(k+1)/2的下标
if(s[l]>k/2) ans+=n-l;
else if(s[l]==k/2) ans+=n-l+1;
cout<<ans<<endl;
}
D
可惜我赛前不久还做过滑动窗口的题,赛时却一直调不出来 /_ \
分析
就是在数组a中找有多少个长度为m的子段,满足子段内元素与b数组的元素至少有k个相同,我们可以枚举长度为m的子段,用桶数组维护当前子段的元素种类数,更新就是当长度大于m时,减去子段第一个元素的种类数,再判断一下此时该元素的种类数是否小于b数组中的种类数,是的话匹配数now--
代码
const int N=2e5+5,M=1e6+5;
int a[N],b[N],tb[M],ta[M];
void solve(){
int n,m,k;cin>>n>>m>>k;
rep(i,1,n){
cin>>a[i];
}
rep(i,1,m){
cin>>b[i];
tb[b[i]]++;
}
int j=0,now=0,ans=0;
rep(i,1,n){
ta[a[i]]++;//对于每个新元素,将其加入桶中
if(ta[a[i]]<=tb[a[i]]) now++;
j=i-m;
if(j>=1){//子段长度大于m时,删除第一个元素的种类数
ta[a[j]]--;
if(ta[a[j]]<tb[a[j]]) now--;//若相等则说明删除该元素对匹配数无影响
}
if(j>=0&&now>=k) ans++;
}
//清空桶数组,用memset会t
rep(i,1,n) ta[a[i]]=0;
rep(i,1,m) tb[b[i]]=0;
cout<<ans<<endl;
}
E
这题让我想起了之前还没补的一道题 3492: 王阿姨处理信号,也是01字符串,也需要做区间处理……
知识点
利用异或差分数组进行区间取反
常用在只有01两种元素的序列中
int n;string s;cin>>n>>s;
s=' '+s;
int l,r;cin>>l>>r;
//将区间[l,r]取反
d[l]^=1,d[r+1]^=1;
rep(i,1,n){
d[i]^=d[i-1];
cout<<((s[i]-'0')^d[i]);
}
分析
从大到小枚举取反区间的长度k,若遇到s[i]=0,则对[i,i+k-1]进行区间取反,若有k合法就跳出
代码
const int N=1e4+5;
int d[N];
void solve(){
int n;string s;cin>>n>>s;
s=' '+s;
per(k,n,1){//枚举取反区间
bool f=1;
rep(i,1,n) d[i]=0;//异或差分数组,d[l]=d[r]=1表示[l,r-1]均取反
rep(i,1,n){
d[i]^=d[i-1];//类似差分数组做前缀和还原为当前数
int x=(s[i]-'0');
//cout<<k<<" "<<i<<" "<<x<<endl;
if(x^d[i]==0){
/*
若x=d[i]=1,表示当前数此前已被取反为0,需要再取反
若x=d[i]=0,表示当前数原本就是0,需要取反
*/
if(i+k-1>n){//若取反区间的终点大于n,由于已无法操作,故当前k不可行
f=0;
break;
}
d[i]^=1;
d[i+k]^=1;
}
}
if(f){
cout<<k<<endl;
break;
}
}
}
CF-938(C-E)的更多相关文章
- ORA-00494: enqueue [CF] held for too long (more than 900 seconds) by 'inst 1, osid 5166'
凌晨收到同事电话,反馈应用程序访问Oracle数据库时报错,当时现场现象确认: 1. 应用程序访问不了数据库,使用SQL Developer测试发现访问不了数据库.报ORA-12570 TNS:pac ...
- cf之路,1,Codeforces Round #345 (Div. 2)
cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅..... ...
- cf Round 613
A.Peter and Snow Blower(计算几何) 给定一个点和一个多边形,求出这个多边形绕这个点旋转一圈后形成的面积.保证这个点不在多边形内. 画个图能明白 这个图形是一个圆环,那么就是这个 ...
- ARC下OC对象和CF对象之间的桥接(bridge)
在开发iOS应用程序时我们有时会用到Core Foundation对象简称CF,例如Core Graphics.Core Text,并且我们可能需要将CF对象和OC对象进行互相转化,我们知道,ARC环 ...
- [Recommendation System] 推荐系统之协同过滤(CF)算法详解和实现
1 集体智慧和协同过滤 1.1 什么是集体智慧(社会计算)? 集体智慧 (Collective Intelligence) 并不是 Web2.0 时代特有的,只是在 Web2.0 时代,大家在 Web ...
- CF memsql Start[c]UP 2.0 A
CF memsql Start[c]UP 2.0 A A. Golden System time limit per test 1 second memory limit per test 256 m ...
- CF memsql Start[c]UP 2.0 B
CF memsql Start[c]UP 2.0 B B. Distributed Join time limit per test 1 second memory limit per test 25 ...
- CF #376 (Div. 2) C. dfs
1.CF #376 (Div. 2) C. Socks dfs 2.题意:给袜子上色,使n天左右脚袜子都同样颜色. 3.总结:一开始用链表存图,一直TLE test 6 (1)如果需 ...
- CF #375 (Div. 2) D. bfs
1.CF #375 (Div. 2) D. Lakes in Berland 2.总结:麻烦的bfs,但其实很水.. 3.题意:n*m的陆地与水泽,水泽在边界表示连通海洋.最后要剩k个湖,总要填掉多 ...
- CF #374 (Div. 2) D. 贪心,优先队列或set
1.CF #374 (Div. 2) D. Maxim and Array 2.总结:按绝对值最小贪心下去即可 3.题意:对n个数进行+x或-x的k次操作,要使操作之后的n个数乘积最小. (1)优 ...
随机推荐
- XAF新手入门 - 数据字典示例
前言 通过前面文章的介绍,大家应该对模块与类型信息子系统有所了解,再通过一个示例来加深大家对它的理解. 在准备写这个系列文章之前,就准备是概念+示例的组合,这样大家对概念的理解会更深刻.之前的规划是在 ...
- vid = two 切开 分开 - 两个眼睛 还有看的含义 - 词根
vid = two 切开 分开 - 两个眼睛 还有看的含义 - 词根 vi = wo acs 构词
- springboot listener、filter登录实战
转载自: www.javaman.cn 博客系统访问: http://175.24.198.63:9090/front/index 登录功能 1.前端页面 采用的是layui-admin框架,文中的验 ...
- Android webview只加载10%且出现白屏问题排查解决
原文:Android webview只加载10%且出现白屏问题排查解决 - Stars-One的杂货小窝 问题 有一个主页面,布局里是包含的一个自定义Webview,并且注入了些原生的方法进去,供原生 ...
- 直播预约 | 邀您共同探讨“云XR技术如何改变元宇宙的虚拟体验”
随着数字化时代的到来,元宇宙成为了人们关注的焦点.它是一个虚拟的世界,融合了现实与虚拟的元素,让人们可以以全新的方式进行交互.创作和体验. 云XR技术是元宇宙建设的重要支撑技术之一,元宇宙需要具备高度 ...
- 记录--用js如何实现将手机号中间的几位数字变成****
这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 今天,我们要实现一个很常见并且简单的功能:将手机号中间的几位数变成**** 这个功能其实很常见,比如我们微信的账号安全里面显示的手机号.掘 ...
- 记录--前端实现文件预览(pdf、excel、word、图片)
这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 前端实现文件预览功能 需求:实现一个在线预览pdf.excel.word.图片等文件的功能. 介绍:支持pdf.xlsx.docx.jpg ...
- Zookeeper学习笔记-安装
zookeeper官网地址https://zookeeper.apache.org/ 1.卸载CentOS自带的open jdk,安装oracle jdk(1.8) 2.时间同步 #安装ntpdate ...
- verilog中的数据类型
Verilog中的数据格式 1.基本概念 verilog中写一个数据的通用格式是 n'b000_000_···_000,表示一个n位的二进制数.基于这个通用式,可以将其分为三个部分:位数.加权数和实际 ...
- BorderDet:通过边界特征大幅提升检测准确率,即插即用且速度不慢 | ECCV 2020 Oral
边界对于定位问题十分重要,BorderDet的核心思想BorderAlign巧妙又有效,将边界特征融入到目标定位预测中,而且能够简单地融入到各种目标检测算法中带来较大的性能提升下.在开源实现中,对Bo ...