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)优 ...
随机推荐
- 深入解析:AntSK 0.1.7版本的技术革新与多模型管理策略
在信息技术快速迭代的当下,.Net生态中的AntSK项目凭借其前沿的AI知识库和智能体技术,已经吸引了广大开发者的关注和参与.今天,我要给大家介绍的主角,AntSK 0.1.7版本,无疑将是这个开源项 ...
- System.out.print重定向到文件实例
该代码可以实现让System.out.print输出内容不再打印到控制台,而是输出到指定的文件中 <strong><span style="font-size:24px;& ...
- CMake基本配置与注意事项
CMake基本配置与注意事项 目录 CMake基本配置与注意事项 CMake message打印日志 find_library查找一个NDK工具中的库 添加多个源文件 CMake中引用其他的 CMak ...
- codeforce Round 934 div2 个人题解(A~C)
A. Destroying Bridges 时间限制: 1秒 内存限制: 256兆 输入: 标准输入 输出: 标准输出 有 $n$ 个岛屿,编号为 $1,2,-,n$.最初,每对岛屿都由一座桥连接.因 ...
- Python实现SQL注入脚本
实验环境 攻击主机IP:172.18.53.145 目标主机IP:172.18.53.11 此处的靶场是Vulnhub中的WEB MACHINE: (N7) 靶场测试 访问靶场的登录页面,使用sqlm ...
- 灰狼优化算法(MOGWO)
灰狼优化算法(MOGWO) 摘要 固定大小的外部档案用来保存帕累托优化解 在多目标搜索空间中,这个档案被用来定义狼群社会等级和捕猎行为 这个算法在10个多目标测试集进行测试,并与MOEA/D和MOPS ...
- 应急响应靶机训练-Linux2
靶机来源: 知攻善防实验室公众号 https://mp.weixin.qq.com/s/xf2FgkrjZg-yWlB9-pRXvw 我是在另一台主机上通过ssh连接到靶机进行解题的,我的ip为192 ...
- koa2整合mysql
引入mysql包 npm install mysql 封装mysql 创建mysql.js文件放在utils(工具包)中 使用pool连接池 mysql.js //封装mysql const mysq ...
- C#通过文件头判断flv文件
代码如下: private void button1_Click(object sender, EventArgs e) { string path = Application.StartupPath ...
- 什么是GRAY色彩空间
GRAY色彩空间通常指的是灰度图像,灰度图像是一种每个像素都是从黑到白,被处理为256个灰度级别的单色图像.这256个灰度级别分别用区间[0,255]中的数值表示,其中,"0"表示 ...