题目背景

阿宝上学了,今天老师拿来了一块很长的涂色板。

题目描述

色板长度为L,L是一个正整数,所以我们可以均匀地将它划分成L块1厘米长的小方格。并从左到右标记为1, 2, ... L。现在色板上只有一个颜色,老师告诉阿宝在色板上只能做两件事:1. "C A B C" 指在A到 B 号方格中涂上颜色 C。2. "P A B" 指老师的提问:A到 B号方格中有几种颜色。学校的颜料盒中一共有 T 种颜料。为简便起见,我们把他们标记为 1, 2, ... T. 开始时色板上原有的颜色就为1号色。 面对如此复杂的问题,阿宝向你求助,你能帮助他吗?

输入输出格式

输入格式:

第一行有3个整数 L (1 <= L <= 100000), T (1 <= T <= 30) 和 O (1 <= O <= 100000). 在这里O表示事件数, 接下来 O 行, 每行以 "C A B C" 或 "P A B" 得形式表示所要做的事情(这里 A, B, C 为整数, 可能A> B)

输出格式:

对于老师的提问,做出相应的回答。每行一个整数。

输入输出样例

输入样例#1:

  1. 2 2 4
  2. C 1 1 2
  3. P 1 2
  4. C 2 2 2
  5. P 1 2
输出样例#1:

  1. 2
  2. 1
    分析:这道题肯定是要用线段树来做,但是要怎么保存信息呢?保存颜色数肯定不对,我们要保存拥有哪些颜色,但是用数组又不太好,观察发现颜色的个数非常少,所以可以转化为二进制来做,每次pushup就用|操作就好了.
  1. #include <cstdio>
  2. #include <cstring>
  3. #include <iostream>
  4. #include <algorithm>
  5. #include <cmath>
  6.  
  7. using namespace std;
  8.  
  9. int L,T,O,c[],flag[];
  10.  
  11. void pushup(int o)
  12. {
  13. c[o] = c[o * ] | c[o * + ];
  14. }
  15.  
  16. void pushdown(int o)
  17. {
  18. if (flag[o])
  19. {
  20. flag[o * ] = flag[o * + ] = flag[o];
  21. c[o * ] = c[o * + ] = flag[o];
  22. flag[o] = ;
  23. }
  24. }
  25.  
  26. void build(int l,int r,int o)
  27. {
  28. if (l == r)
  29. {
  30. c[o] = ;
  31. return;
  32. }
  33. int mid = (l + r) >> ;
  34. build(l,mid,o * );
  35. build(mid + ,r,o * + );
  36. pushup(o);
  37. }
  38.  
  39. void update(int l,int r,int o,int x,int y,int v)
  40. {
  41. if (x <= l && r <= y)
  42. {
  43. c[o] = v;
  44. flag[o] = v;
  45. return;
  46. }
  47. pushdown(o);
  48. int mid = (l + r) >> ;
  49. if (x <= mid)
  50. update(l,mid,o * ,x,y,v);
  51. if (y > mid)
  52. update(mid + ,r,o * + ,x,y,v);
  53. pushup(o);
  54. }
  55.  
  56. int query(int l,int r,int o,int x,int y)
  57. {
  58. if (x <= l && r <= y)
  59. return c[o];
  60. pushdown(o);
  61. int cnt = ,mid = (l + r) >> ;
  62. if (x <= mid)
  63. cnt |= query(l,mid,o * ,x,y);
  64. if (y > mid)
  65. cnt |= query(mid + ,r,o * + ,x,y);
  66. return cnt;
  67. }
  68.  
  69. int main()
  70. {
  71. scanf("%d%d%d",&L,&T,&O);
  72. build(,L,);
  73. for (int i = ; i <= O; i++)
  74. {
  75. char op[];
  76. int a,b,c;
  77. scanf("%s",op);
  78. if (op[] == 'C')
  79. {
  80. scanf("%d%d%d",&a,&b,&c);
  81. if (a > b)
  82. swap(a,b);
  83. update(,L,,a,b, << (c - ));
  84. }
  85. else
  86. {
  87. scanf("%d%d",&a,&b);
  88. if (a > b)
  89. swap(a,b);
  90. int ans = query(,L,,a,b);
  91. int cnt = ;
  92. while (ans)
  93. {
  94. if (ans & )
  95. cnt++;
  96. ans >>= ;
  97. }
  98. printf("%d\n",cnt);
  99. }
  100. }
  101.  
  102. return ;
  103. }
  1.  

洛谷P1558 色板游戏的更多相关文章

  1. 洛谷P1558 色板游戏 [线段树]

    题目传送门 色板游戏 题目背景 阿宝上学了,今天老师拿来了一块很长的涂色板. 题目描述 色板长度为L,L是一个正整数,所以我们可以均匀地将它划分成L块1厘米长的小方格.并从左到右标记为1, 2, .. ...

  2. 洛谷 P1558 色板游戏

    洛谷 题解里面好像都是压位什么的, 身为蒟蒻的我真的不会, 所以就来谈谈我的30颗线段树蠢方法吧! 这题初看没有头绪. 然后发现颜色范围好像只有30: 所以,我就想到一种\(sao\)操作,搞30颗线 ...

  3. P1558 色板游戏 状压线段树

    P1558 色板游戏 状压线段树 题面 洛谷P1558 每次不同颜色覆盖一段区间,每次询问一段区间有多少种颜色 因为颜色数\(T\)很小,使用二进制表示状态当前区间有那些颜色,二进制第\(i\)位表示 ...

  4. P1558 色板游戏

    P1558 色板游戏 题目背景 阿宝上学了,今天老师拿来了一块很长的涂色板. 题目描述 色板长度为L,L是一个正整数,所以我们可以均匀地将它划分成L块1厘米长的小方格.并从左到右标记为1, 2, .. ...

  5. 洛谷 P2197 nim游戏

    洛谷 P2197 nim游戏 题目描述 甲,乙两个人玩Nim取石子游戏. nim游戏的规则是这样的:地上有n堆石子(每堆石子数量小于10000),每人每次可从任意一堆石子里取出任意多枚石子扔掉,可以取 ...

  6. 洛谷 P1965 转圈游戏

    洛谷 P1965 转圈游戏 传送门 思路 每一轮第 0 号位置上的小伙伴顺时针走到第 m 号位置,第 1 号位置小伙伴走到第 m+1 号位置,--,依此类推,第n − m号位置上的小伙伴走到第 0 号 ...

  7. AC日记——色板游戏 洛谷 P1558

    色板游戏 思路: sb题: 代码: #include <bits/stdc++.h> using namespace std; #define maxn 100005 struct Tre ...

  8. 洛谷 P1000 超级玛丽游戏

    P1000 超级玛丽游戏 题目背景 本题是洛谷的试机题目,可以帮助了解洛谷的使用. 建议完成本题目后继续尝试P1001.P1008. 题目描述 超级玛丽是一个非常经典的游戏.请你用字符画的形式输出超级 ...

  9. 【流水调度问题】【邻项交换对比】【Johnson法则】洛谷P1080国王游戏/P1248加工生产调度/P2123皇后游戏/P1541爬山

    前提说明,因为我比较菜,关于理论性的证明大部分是搬来其他大佬的,相应地方有注明. 我自己写的部分换颜色来便于区分. 邻项交换对比是求一定条件下的最优排序的思想(个人理解).这部分最近做了一些题,就一起 ...

随机推荐

  1. 1.5 JAVA的高并发编程

    一.多线程的基本知识 1.1进程与线程的介绍(上个博客1.4中已经详细介绍进程和线程) 程序运行时在内存中分配自己独立的运行空间,就是进程 线程:它是位于进程中,负责当前进程中的某个具备独立运行资格的 ...

  2. 集合set、map、list

    一.set 无序.可重复 public static void main(String[] args){ Set<String> set=new HashSet<String> ...

  3. java 乐观锁 vs 悲观锁

    在数据库的锁机制中介绍过,数据库管理系统(DBMS)中的并发控制的任务是确保在多个事务同时存取数据库中同一数据时不破坏事务的隔离性和统一性以及数据库的统一性. 悲观锁其实就是 完全同步 比如 sync ...

  4. 深度系统(deepin)与win10双系统切换设置

    之前在win10下安装了深度系统,我不知道其他人在双系统切换的时候是否需要更改BIOS参数,我根据我的实际情况给出双系统切换设置的解决方案. 1.开机后进入选项System setup 2.按照下图选 ...

  5. Right-BICEP 测试四则运算程序

    测试方法:      Right-BICEP 测试计划: 1.边界测试是否正确 2.负数表示是否实现 3.是否有乘除法 4.是否可以选择题目数量 5.是否有输出方式 6.是否有括号 7.是否有重复查询 ...

  6. 寒假c++学习计划

    课程选择 概览 清华大学 C++语言程序设计基础 深入学习 清华大学 C++语言程序设计进阶 (2015年秋) 理由 清华大学郑莉老师的课浅显易懂,很适合我这种小白,再加上学习过c语言理解c++基础并 ...

  7. mysql hql异常

    org.springframework.dao.InvalidDataAccessResourceUsageException:  could not execute query; nested ex ...

  8. Scrum 项目准备4.0

    4.0----------------------------------------------- 1.准备看板. 形式参考图4. 2.任务认领,并把认领人标注在看板上的任务标签上. 先由个人主动领 ...

  9. BurpSuite 激活破解

    1.下载软件关于Burp Suite, 它是进行Web应用安全测试的一个集成平台,无缝融合各种安全工具并提供全面的接口适配,支持完整的Web应用测试流程,从最初的映射和应用程序的攻击面分析到发现和利用 ...

  10. (转)Elasticsearch search-guard 插件部署

    我之前写了ELK+shield的部署文档,由于shield是商业收费的,很多人都推崇开源项目search-guard来做ELK的安全组件,准确来说是elasticsearch的安全组件.search- ...