信息学奥赛一本通 1539:简单题 | 洛谷 P5057 [CQOI2006] 简单题

【题目链接】

ybt 1539:简单题
洛谷 P5057 [CQOI2006] 简单题

【题目考点】

1. 树状数组

模板题及讲解:洛谷 P3374 【模板】树状数组

【解题思路】

解法1:树状数组

该有01构成数组初值都为0。
某位置的元素被修改奇数次后值为1,被修改偶数次后值为0。
因此只需要求出某位置元素被修改的次数,即可得到该位置的数值。
每次修改是让连续的一段序列翻转,也就是选择数组的一段区间,将该区间中的元素取反(0变为1,1变为0)。
求某元素被修改的次数,就是求有多少个区间覆盖的该元素。
假想存在数组:cL,cR
c L i cL_i cLi表示区间左端点为i的区间数。
c R i cR_i cRi表示区间右端点为i的区间数。
s u m L i sumL_i sumLi c L cL cL的前缀和,即左端点L在[1,i]范围内的区间数
s u m R i sumR_i sumRi c R cR cR的前缀和,右端点R在[1,i]范围内的区间数
分别对cL、cR数组建立树状数组,借助树状数组可以在有单点修改的情况下,以 O ( log ⁡ n ) O(\log n) O(logn)时间复杂度求出序列的前缀和。

如果区间[L, R]包含x,则区间左端点L一定小于等于x。
如果区间[L, R]的右端点R小于x,这样的区间的左端点L也一定小于x。
考察左端点 L ≤ x L\le x Lx的区间,有两类:

  • 右端点 R < x R<x R<x的区间
  • 右端点 R ≥ x R\ge x Rx的区间,即包含x的区间。

左端点 L ≤ x L\le x Lx的区间数量为 s u m L x sumL_x sumLx
右端点 R < x R < x R<x的区间数量为 s u m R x − 1 sumR_{x-1} sumRx1
设包含x的区间的数量为 a n s x ans_x ansx
有: s u m L x = s u m R x − 1 + a n s x sumL_x = sumR_{x-1}+ans_x sumLx=sumRx1+ansx
a n s x = s u m L x − s u m R x − 1 ans_x = sumL_x-sumR_{x-1} ansx=sumLxsumRx1

具体做法:

  1. 如果需要将区间[l, r]中的元素取反,则存在一个区间 [ l , r ] [l, r] [l,r],使 c L l cL_l cLl增加1, c R r cR_r cRr增加1。树状数组进行相应的单点修改操作。
  2. 如果需要查询第x元素的值,则通过 a n s x = s u m L x − s u m R x − 1 ans_x=sumL_x-sumR_{x-1} ansx=sumLxsumRx1求出x被区间修改的次数 a n s x ans_x ansx,如果 a n s x ans_x ansx为奇数,第x元素值为1,否则第x元素值为0。

解法2:线段树 维护区间的异或值

考虑对原数字序列进行区间修改、区间查询。
区间修改的操作为对某区间中每个元素都进行01取反,对于由01构成的序列,01取反操作即为xor 1(异或1)操作。
因为 0 x o r 1 = 1 0\ xor\ 1 = 1 0 xor 1=1 1 x o r 1 = 0 1\ xor\ 1 = 0 1 xor 1=0
区间标记tag设为本段区间中的元素需要被异或的值,即本段区间每个元素实际的值为当前值 x o r t a g \ xor\ tag  xor tag
注意进行区间修改、单点查询前需要进行标记下传。

【题解代码】

解法1:树状数组
  • 写法1:为treeL、treeR设置两套树状数组处理函数
#include<bits/stdc++.h>
using namespace std;
#define N 100005
int n, m, treeL[N], treeR[N];//cL[i]:左端点为i的区间数,treeL:cL的树状数组
int lowbit(int x)
{return x & -x;
}
void updateL(int i)//cL[i]++
{for(int x = i; x <= n; x += lowbit(x))treeL[x]++;
}
void updateR(int i)//cR[i]++
{for(int x = i; x <= n; x += lowbit(x))treeR[x]++;
}
int sumL(int i)//cL的前缀和
{int s = 0;for(int x = i; x > 0; x -= lowbit(x))s += treeL[x];return s;
}
int sumR(int i)//cR的前缀和
{int s = 0;for(int x = i; x > 0; x -= lowbit(x))s += treeR[x];return s;
}
int main()
{ios::sync_with_stdio(false);cin.tie(nullptr);int t, l, r, x;cin >> n >> m;for(int i = 1; i <= m; ++i){cin >> t;if(t == 1){cin >> l >> r;updateL(l);updateR(r);}else{cin >> x;cout << (sumL(x)-sumR(x-1))%2 << '\n';//初值为0,修改偶数次为0,修改奇数次为1 }}return 0;
}
  • 写法2:只设一套树状数组处理函数,传入数组地址
#include<bits/stdc++.h>
using namespace std;
#define N 100005
int n, m, treeL[N], treeR[N];//cL[i]:左端点为i的区间数,treeL:cL的树状数组 cR[i]:右端点为i的区间数,treeR:cR的树状数组
int lowbit(int x)
{return x & -x;
}
void update(int i, int *tree)//cL[i]++,或cR[i]++。
{//传入数组名treeL或treeR,可以修改对应传入的tree数组for(int x = i; x <= n; x += lowbit(x))tree[x]++;
}
int sum(int i, int *tree)//求cL或cR的前缀和
{int s = 0;for(int x = i; x > 0; x -= lowbit(x))s += tree[x];return s;
}
int main()
{ios::sync_with_stdio(false);cin.tie(nullptr);int t, l, r, x;cin >> n >> m;for(int i = 1; i <= m; ++i){cin >> t;if(t == 1){cin >> l >> r;update(l, treeL);update(r, treeR);}else{cin >> x;//x为题目中的i,求x位置的值 cout << (sum(x, treeL)-sum(x-1, treeR))%2 << '\n';//初值为0,修改偶数次为0,修改奇数次为1 }}return 0;
}

解法2:线段树 维护区间异或值

#include<bits/stdc++.h>
using namespace std;
#define N 100005
struct Node
{int val, l, r, tag;
} tree[4*N];
int n, m;
void addTag(int i)
{tree[i].tag ^= 1;tree[i].val ^= 1;
}
void pushDown(int i)
{if(tree[i].tag == 0)return;addTag(2*i);addTag(2*i+1);tree[i].tag = 0;
}
void build(int i, int l, int r)
{tree[i].l = l, tree[i].r = r;if(l == r)//tree[i].val初值都为0 return;int mid = (l+r)/2;build(2*i, l, mid);build(2*i+1, mid+1, r);
}
void update(int i, int l, int r)//a[l]~a[r]取反 
{if(tree[i].r < l || tree[i].l > r)return;if(l <= tree[i].l && tree[i].r <= r)return addTag(i);pushDown(i);update(2*i, l, r);update(2*i+1, l, r);
}
int query(int i, int x)//a[x]
{if(tree[i].l == tree[i].r)return tree[i].val;pushDown(i); if(x <= tree[2*i].r)return query(2*i, x);else//x >= tree[2*i+1].l return query(2*i+1, x);
}
int main()
{ios::sync_with_stdio(false);cin.tie(nullptr);int t, l, r, x;cin >> n >> m;build(1, 1, n);while(m--){cin >> t;if(t == 1){cin >> l >> r;update(1, l, r); }else//t == 2{cin >> x;cout << query(1, x) << '\n';}}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/81523.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

仓颉开发语言入门教程:搭建开发环境

仓颉开发语言作为华为为鸿蒙系统自研的开发语言&#xff0c;虽然才发布不久&#xff0c;但是它承担着极其重要的历史使命。作为鸿蒙开发者&#xff0c;掌握仓颉开发语言将成为不可或缺的技能&#xff0c;今天我们从零开始&#xff0c;为大家分享仓颉语言的开发教程&#xff0c;…

玉米籽粒发育

成熟玉米籽粒的结构 玉米籽粒的组成 成熟的玉米籽粒主要由以下三部分组成&#xff1a; 母体组织&#xff1a;包括种皮、胎座和花梗。种皮由珠被发育而来&#xff0c;起到保护种子的作用&#xff0c;并在种子的休眠和萌发中发挥重要作用。胚&#xff1a;包含根分生组织、茎分…

sherpa-ncnn:音频处理跟不上采集速度 -- 语音转文本大模型

目录 1. 问题报错2. 解决方法 1. 问题报错 报错&#xff1a; An overrun occurred, which means the RTF of the current model on your board is larger than 1. You can use ./bin/sherpa-ncnn to verify that. Please select a smaller model whose RTF is less than 1 fo…

Postman一直打不开的解决办法

Postman 是一款非常流行的开源 API 开发工具&#xff0c;主要用于构建、测试、调试和文档化应用程序接口&#xff08;API&#xff09;。但有时它的性能不会特别稳定&#xff0c;功能限制和扩展性不足&#xff1b;应用于开发、测试、运维等环节&#xff0c;尤其在开发 RESTful A…

问题|对只允许输入的变量是否进行了更改

“对只允许输入的变量是否进行了更改”这一问题的核心是&#xff1a;在编程中&#xff0c;某些变量被设计为仅用于输入&#xff08;只读&#xff09;&#xff0c;但在代码中可能被意外修改&#xff0c;导致潜在错误。以下是详细解释&#xff1a; 1. 什么是“只允许输入的变量”…

RPC与SOAP的区别

一.RPC&#xff08;远程过程调用&#xff09;和SOAP&#xff08;简单对象访问协议&#xff09;均用于实现分布式系统中的远程通信&#xff0c;但两者在设计理念、协议实现及应用场景上存在显著差异。 二.对比 1.设计理念 2.协议规范 3.技术特性 4.典型应用场景 5.总结 三.总结…

c#的内存指针操作(仅用于记录)

c#也可以直接操作内存指针&#xff0c;如下为示例&#xff1a; unsafe {byte[] a {1,2,3};fixed (byte* p1 a, p2 &a[^1]){Debugger.Log(1, "test", $"max index:{p2-p1}");Debugger.Log(1, "test", $"address:{(long)p1:X}")…

Jsp技术入门指南【十三】基于 JSTL SQL 标签库实现 MySQL 数据库连接与数据分页展示

Jsp技术入门指南【十三】基于 JSTL SQL 标签库实现 MySQL 数据库连接与数据分页展示 前言一、回顾SQL标签的内容1. 什么是JSTL SQL标签&#xff1f;2.为什么要用SQL标签&#xff1f;3.第一步&#xff1a;引入SQL标签库4. SQL标签的核心功能&#xff1a;连接数据库标签常用属性&…

羽毛球订场小程序源码介绍

基于ThinkPHP、FastAdmin以及UniApp开发的羽毛球订场小程序源码&#xff0c;这款小程序旨在为羽毛球爱好者提供便捷的场地预订服务。 该小程序前端采用UniApp框架开发&#xff0c;具有良好的跨平台兼容性&#xff0c;可以一键发布至iOS和Android平台&#xff0c;极大地提高了开…

Unreal Engine: Windows 下打包 AirSim项目 为 Linux 平台项目

环境&#xff1a; Windows: win10, UE4.27, Visual Studio 2022 Community.Linux: 22.04 windows环境安装教程&#xff1a; 链接遇到的问题&#xff08;问题&#xff1a;解决方案&#xff09; 点击Linux打包按钮&#xff0c;跳转至网页而不是执行打包流程&#xff1a;用VS打开项…

SpringBoot 3.x 集成 MyBatisPlus

文章目录 集成 MyBatisPlus第 1 步:创建 SpringBoot 项目第 2 步:添加 MyBatisPlus 依赖第 3 步:编写 CRUD 代码创建 Entity创建 Mapper创建 Service编写 Controller第 4 步:执行初始化 SQL第 5 步:配置第 6 步:测试测试 ControllerMapper 层单元测试参考🚀 目标 1:基…

java基础-抽象类和抽象方法

1.abstract 可以修饰&#xff1a;类、方法 &#xff08;1&#xff09;修饰类&#xff1a; 类不能被实例化&#xff1b; 抽象类一定有构造器&#xff0c;便于子类实例化时调用&#xff1b; &#xff08;2&#xff09;修饰方法&#xff1a;抽象方法 只有方法的声明&#xff…

解决电脑问题(8)——网络问题

电脑网络出现问题的原因较为复杂&#xff0c;以下是从网络连接、网络配置以及网络环境等方面的常见问题及解决方法&#xff1a; 网络连接问题 检查物理连接&#xff1a;对于有线网络&#xff0c;检查网线是否插好&#xff0c;网线有无破损、断裂等情况。对于无线网络&#xff…

ubuntu 20.04 ping baidu.coom可以通,ping www.baidu.com不通 【DNS出现问题】解决方案

ping baidu.coom可以通&#xff0c;ping www.baidu.com不通【DNS出现问题】解决方案 检查IPV6是否有问题 # 1. 检查 IPv6 地址&#xff0c;记住网络接口的名称 ip -6 addr show# 2. 测试本地 IPv6&#xff0c;eth0换成自己的网络接口名称 ping6 ff02::1%eth0# 3. 检查路由 ip…

【AI生成PPT】使用ChatGPT+Overleaf自动生成学术论文PPT演示文稿

【AI生成PPT】使用ChatGPTOverleaf自动生成学术论文PPT演示文稿 文章摘要&#xff1a;使用ChatGPTBeamer自动生成学术论文PPT演示文稿​​Beamer​​是什么Overleaf编辑工具ChatGPT生成Beamer Latex代码论文获取prompt设计 生成结果 文章摘要&#xff1a; 本文介绍了一种高效利…

JVM 垃圾回收器

以下是对主流 JVM 垃圾回收器的详细解析&#xff0c;涵盖 一、Serial GC&#xff08;单线程串行回收器&#xff09; 二、Parallel GC&#xff08;吞吐量优先回收器&#xff09; 三、CMS&#xff08;Concurrent Mark Sweep&#xff0c;低延迟回收器&#xff09; 四、G1&…

从零开始学习three.js(21):一文详解three.js中的矩阵Matrix和向量Vector

一、三维世界的数学基石 在Three.js的三维世界里&#xff0c;所有视觉效果的实现都建立在严密的数学基础之上。其中向量&#xff08;Vector&#xff09; 和矩阵&#xff08;Matrix&#xff09; 是最核心的数学工具&#xff0c;它们就像构建数字宇宙的原子与分子&#xff0c;支…

ArcGIS Pro 3.4 二次开发 - 内容

环境&#xff1a;ArcGIS Pro SDK 3.4 .NET 8 文章目录 内容1 工程1.1 创建一个空工程1.2 使用指定名称创建新工程1.3 使用Pro的默认设置创建新工程1.4 使用自定义模板文件创建新工程1.5 使用 ArcGIS Pro 提供的模板创建工程1.6 打开现有工程1.7 获取当前工程1.8 获取当前工程的…

【Python-Day 15】深入探索 Python 字典 (下):常用方法、遍历、推导式与嵌套实战

Langchain系列文章目录 01-玩转LangChain&#xff1a;从模型调用到Prompt模板与输出解析的完整指南 02-玩转 LangChain Memory 模块&#xff1a;四种记忆类型详解及应用场景全覆盖 03-全面掌握 LangChain&#xff1a;从核心链条构建到动态任务分配的实战指南 04-玩转 LangChai…

31、魔法生物图鉴——React 19 Web Workers

一、守护神协议&#xff08;核心原理&#xff09; 1. 灵魂分裂术&#xff08;线程架构&#xff09; // 主组件中初始化Workerconst workerRef useRef(null);​useEffect(() > {workerRef.current new Worker(new URL(./creatureWorker.js, import.meta.url));workerRef.…