尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

P8271 [USACO22OPEN] COW Operations S

P8271 [USACO22OPEN] COW Operations S
📅 发布时间:2026/6/19 8:01:27

洛谷

蒟蒻给一个时间复杂度较劣的线段树做法。

我们可以发现两个字符处理的结果和处理的顺序没有关系,那么我们可以先考虑将每一部分都尝试合成一个或没有字符,再进行合并。

那么我们其实可以考虑使用线段树直接维护每个区间内经过合成剩下了什么,即可判断是否正确。

代码:

#include<bits/stdc++.h>
#define int long long
using namespace std;
char s[200005];
int merge(int a,int b){if(a==0)return b;if(b==0)return a;if(a==b)return 0;if(a==1&&b==2||a==2&&b==1)return 3;if(a==1&&b==3||a==3&&b==1)return 2;if(a==2&&b==3||a==3&&b==2)return 1;
}
struct ST{int c[800005];#define ls p<<1#define rs p<<1|1void pushup(int p){c[p]=merge(c[ls],c[rs]);}void build(int p,int l,int r){if(l==r){if(s[l]=='C')c[p]=1;else if(s[l]=='O')c[p]=2;else c[p]=3;return;}int mid=l+r>>1;build(ls,l,mid),build(rs,mid+1,r);pushup(p);}int query(int p,int l,int r,int L,int R){if(l>=L&&r<=R)return c[p];int mid=l+r>>1;if(mid>=L&&mid<R)return merge(query(ls,l,mid,L,R),query(rs,mid+1,r,L,R));if(mid>=L)return query(ls,l,mid,L,R);return query(rs,mid+1,r,L,R);}
}seg;
signed main(){cin>>s+1;int n=strlen(s+1);seg.build(1,1,n);int q;cin>>q;int l,r;while(q--){cin>>l>>r;int tmp=seg.query(1,1,n,l,r);if(tmp==1)cout<<"Y";else cout<<"N";}return 0;
}

相关新闻

  • Manim介绍
  • P6803 [CEOI 2020] 星际迷航
  • CF1970E3 Trails (Hard)

最新新闻

  • o3-mini作为工程协作者的ML项目落地实践
  • ONNX工程化落地:从模型转换到边缘部署的全链路实践
  • 5个鼠标魔法技巧:让普通鼠标在macOS上超越苹果触控板的完整指南
  • windows权限划分
  • OpenSpeedy:3分钟学会使用开源游戏加速工具,告别卡顿延迟
  • DeepSeek效率革命:大模型推理优化与工程化落地实践

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号