CQOI 2006 简单题

有一个 n 个元素的数组,每个元素初始均为 0。有 m 条指令,要么让其中一段连续序列数字反转——0 变 1,1 变 0(操作 11),要么询问某个元素的值(操作 2)。

例如当 n=20时,10条指令如下:

操作 回答 操作后的数组
1 1 10 N/A 11111111110000000000
2 6 1 111111​11110000000000
2 12 0 111111111100​00000000
1 5 12 N/A 11110000001100000000
2 6 0 111100​00001100000000
2 15 0 111100000011000​00000
1 6 16 N/A 11110111110011110000
1 11 17 N/A 11110111111100001000
2 12 1 111101111111​00001000
2 6 1 111101​11111100001000

输入格式

第一行包含两个整数 n,m,表示数组的长度和指令的条数;
以下 m 行,每行的第一个数 tt 表示操作的种类:

  • 若 t=1,则接下来有两个数 L, R,表示区间 [L, R] 的每个数均反转;
  • 若 t=2,则接下来只有一个数 i,表示询问的下标。

输出格式

每个操作 2 输出一行(非 0 即 1),表示每次操作 2 的回答。

样例

样例输入

  1. 20 10
  2. 1 1 10
  3. 2 6
  4. 2 12
  5. 1 5 12
  6. 2 6
  7. 2 15
  8. 1 6 16
  9. 1 11 17
  10. 2 12
  11. 2 6

样例输出

  1. 1
  2. 0
  3. 0
  4. 0
  5. 1
  6. 1

数据范围与提示

对于 50% 的数据,1≤n≤10^3,1≤m≤10^4;

对于 100% 的数据,1≤n≤10^5,1≤m≤5×10^5,保证 L≤R。

__________________________________________________________________________________________________________________________

树状数组,只是把求和变成了异或!

___________________________________________________________________________________________________________________________

  1. 1 #include<bits/stdc++.h>
  2. 2 using namespace std;
  3. 3 const int maxn=1e5+10;
  4. 4 bool sz[maxn];
  5. 5 int n,m;
  6. 6 inline int lowbit(int x)
  7. 7 {
  8. 8 return x&-x;
  9. 9 }
  10. 10 void update(int x)
  11. 11 {
  12. 12 for(int i=x;i<=n;i+=lowbit(i))sz[i]=!sz[i];
  13. 13 }
  14. 14 bool get(int x)
  15. 15 {
  16. 16 bool ans=0;
  17. 17 for(int i=x;i;i-=lowbit(i))ans^=sz[i];
  18. 18 return ans;
  19. 19 }
  20. 20 int main()
  21. 21 {
  22. 22 scanf("%d%d",&n,&m);
  23. 23 while(m--)
  24. 24 {
  25. 25 int op,l,r;
  26. 26 scanf("%d",&op);
  27. 27 if(op==1)
  28. 28 {
  29. 29 scanf("%d%d",&l,&r);
  30. 30 update(l);update(r+1);
  31. 31 }
  32. 32 else
  33. 33 {
  34. 34 scanf("%d",&l);
  35. 35 printf("%d\n",get(l));
  36. 36 }
  37. 37 }
  38. 38 return 0;
  39. 39 }

CQOI 2006 简单题的更多相关文章

  1. Loj 【CQOI 2006】简单题,mmp

    #10117. 「一本通 4.1 练习 2」简单题     题目描述 题目来源:CQOI 2006 有一个 nnn 个元素的数组,每个元素初始均为 000.有 mmm 条指令,要么让其中一段连续序列数 ...

  2. loj 10117 简单题(cqoi 2006)

    题目来源:CQOI 2006 有一个 n 个元素的数组,每个元素初始均为 0.有 m条指令,要么让其中一段连续序列数字反转——0变 1,1 变 0(操作 1),要么询问某个元素的值(操作 2). 例如 ...

  3. LOJ#10117. 「一本通 4.1 练习 2」简单题

    LOJ#10117. 「一本通 4.1 练习 2」简单题 题目描述 题目来源:$CQOI 2006$ 有一个$n$个元素的数组,每个元素初始均为$0$.有$m$条指令,要么让其中一段连续序列数字反转— ...

  4. unctf2020 部分简单题题解

    unctf2020 水一波简单题..菜狗前来报道..大佬轻喷..如果有时间做题就好了呜呜呜 misc 1.baba_is_you 题目告诉我们,了解png文件格式. 下载得到一张png格式的图片. 用 ...

  5. BZOJ 2683: 简单题

    2683: 简单题 Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 913  Solved: 379[Submit][Status][Discuss] ...

  6. 【BZOJ-1176&2683】Mokia&简单题 CDQ分治

    1176: [Balkan2007]Mokia Time Limit: 30 Sec  Memory Limit: 162 MBSubmit: 1854  Solved: 821[Submit][St ...

  7. Bzoj4066 简单题

    Time Limit: 50 Sec  Memory Limit: 20 MBSubmit: 2185  Solved: 581 Description 你有一个N*N的棋盘,每个格子内有一个整数,初 ...

  8. Bzoj2683 简单题

    Time Limit: 50 Sec  Memory Limit: 128 MBSubmit: 1071  Solved: 428 Description 你有一个N*N的棋盘,每个格子内有一个整数, ...

  9. 这样leetcode简单题都更完了

    这样leetcode简单题都更完了,作为水题王的我开始要更新leetcode中等题和难题了,有些挖了很久的坑也将在在这个阶段一一揭晓,接下来的算法性更强,我就要开始分专题更新题目,而不是再以我的A题顺 ...

随机推荐

  1. ArrayListHashmap嵌套

    package arrayListHashMap; import java.util.ArrayList; import java.util.HashMap; import java.util.Map ...

  2. File类的特点?如何创建File类对象?Java中如何操作文件内容,什么是Io流Io流如何读取和写入文件?字节缓冲流使用原则?

    重难点提示 学习目标 1.能够了解File类的特点(存在的意义,构造方法,常见方法) 2.能够了解什么是IO流以及分类(IO流的概述以及分类) 3.能够掌握字节输出流的使用(继承体系结构介绍以及常见的 ...

  3. “开源、共享、创新” 2020 中国.NET开发者大会小结

    大会的新闻稿在2020年12月31日正式发布:开源·共享·创新|2020年中国.NET开发者大会圆满收官! , 本文是这篇新闻的补充性文章,仅代表个人对大会的各方面分享内容的一个小结. 在2019年上 ...

  4. @Transactional注解失效的解决方案

    一.前言 开发中我们经常使用 @Transactional注解来启用Spring事务管理,但是如果使用方法不当,会遇到注解不生效该事务回滚的地方却没有回滚的问题. 总结下一般是以下几个原因: @Tra ...

  5. Head First 设计模式 —— 02. 观察者 (Observer) 模式

    思考题 在我们的一个实现中,下列哪种说法正确?(多选) P42 public class WeatherDate { // 实例变量声明 public void measurementsChanged ...

  6. Lesson_strange_words5

    certain 一些 the company's 公司的 implement 实现 plane 平面 sluggishly 迟缓地,缓慢地 frustrated 懊恼的 profiler 分析器,分析 ...

  7. Lesson_strange_words1

    time-between system 分时操作:分时系统 secondary 辅助的,从属的 establish 已确立的 capability 功能 formerly 之前的 combine 结合 ...

  8. Tomcat7,Tomcat8 的manager 配置

    1.打开文件:tomcat目录-->conf-->tomcat-users.xml  2.将以下代码替换原来的所有内容,不要犹豫,就是所有内容. <?xml version=&quo ...

  9. SpringBoot嵌入式Servlet容器

    SpringBoot默认是将Tomcat作为嵌入式的servlet容器. 问题: 如何修改嵌入式的servlet容器? 1)在配置文件中设置对应的属性值 server.port=8081 # Tomc ...

  10. bash shell关联数组总结

    [原创]本博文为原创博文,引用或转发请注明原始出处和链接:https://www.cnblogs.com/dingbj/p/dict_array.html 什么是关联数组? 关联数组相对于索引数组,又 ...