SPOJ MULTQ3 7299 Multiples of 3 (区间更新)
题目连接:http://www.spoj.com/problems/MULTQ3/
- #include <iostream>
- #include <stdio.h>
- #include <string.h>
- #define lson rt<<1,L,mid
- #define rson rt<<1|1,mid+1,R
- /*
- 题意:给出n个数,初试为0,给出两个操作;
- 0 A B :将[A,B]区间中的每个数+1
- 1 A B :询问[A,B]区间中有多少个能被3整除的数。
- 思路:每个节点存储三个值:num0:整除3的个数,num1:除以3余1的个数,num2:除以3余2的个数
- 更新的时候,只要将这三个值互换即可
- */
- using namespace std;
- const int maxn=;
- int n,m;
- struct Node{
- //num0:整除3的个数,num1:除以3余1的个数,num2:除以3余2的个数
- int num0,num1,num2;
- int lazy; //标记该区间+1的次数,如果三次+1相当于不变
- }tree[maxn<<];
- void build(int rt,int L,int R){
- tree[rt].num0=(R-L+);
- tree[rt].num1=tree[rt].num2=;
- tree[rt].lazy=;
- if(L==R)
- return;
- int mid=(R+L)>>;
- build(lson);
- build(rson);
- }
- void pushUp(int rt){
- tree[rt].num0=tree[rt<<].num0+tree[rt<<|].num0;
- tree[rt].num1=tree[rt<<].num1+tree[rt<<|].num1;
- tree[rt].num2=tree[rt<<].num2+tree[rt<<|].num2;
- }
- void pushDown(Node &rt,Node &ls,Node &rs){
- if(rt.lazy==){
- /*
- +1一次:
- num0->num1
- num1->num2
- num2->num0
- */
- int tmp;
- tmp=ls.num0;
- ls.num0=ls.num2;
- ls.num2=ls.num1;
- ls.num1=tmp;
- ls.lazy=(ls.lazy+rt.lazy)%;
- tmp=rs.num0;
- rs.num0=rs.num2;
- rs.num2=rs.num1;
- rs.num1=tmp;
- rs.lazy=(rs.lazy+rt.lazy)%;
- rt.lazy=;
- }
- else if(rt.lazy==){
- /*
- +1二次:
- num0->num2
- num2->num1
- num1->num0
- */
- int tmp;
- tmp=ls.num0;
- ls.num0=ls.num1;
- ls.num1=ls.num2;
- ls.num2=tmp;
- ls.lazy=(ls.lazy+rt.lazy)%;
- tmp=rs.num0;
- rs.num0=rs.num1;
- rs.num1=rs.num2;
- rs.num2=tmp;
- rs.lazy=(rs.lazy+rt.lazy)%;
- rt.lazy=;
- }
- }
- void update(int rt,int L,int R,int l,int r){
- if(l<=L&&R<=r){
- int tmp;
- tmp=tree[rt].num0;
- tree[rt].num0=tree[rt].num2;
- tree[rt].num2=tree[rt].num1;
- tree[rt].num1=tmp;
- tree[rt].lazy=(tree[rt].lazy+)%;
- return;
- }
- pushDown(tree[rt],tree[rt<<],tree[rt<<|]);
- int mid=(L+R)>>;
- if(l<=mid)
- update(lson,l,r);
- if(r>mid)
- update(rson,l,r);
- pushUp(rt);
- }
- int query(int rt,int L,int R,int l,int r){
- if(l<=L&&R<=r){
- return tree[rt].num0;
- }
- pushDown(tree[rt],tree[rt<<],tree[rt<<|]);
- int ret=;
- int mid=(L+R)>>;
- if(l<=mid)
- ret+=query(lson,l,r);
- if(r>mid)
- ret+=query(rson,l,r);
- return ret;
- }
- int main()
- {
- int t,a,b;
- scanf("%d%d",&n,&m);
- build(,,n);
- for(int i=;i<=m;i++){
- scanf("%d%d%d",&t,&a,&b);
- a++;b++;
- if(t==){
- update(,,n,a,b);
- }
- else{
- int ans=query(,,n,a,b);
- printf("%d\n",ans);
- }
- }
- return ;
- }
SPOJ MULTQ3 7299 Multiples of 3 (区间更新)的更多相关文章
- HDU 4348.To the moon SPOJ - TTM To the moon -可持久化线段树(带修改在线区间更新(增减)、区间求和、查询历史版本、回退到历史版本、延时标记不下放(空间优化))
To the moon Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total ...
- HDU 1556 Color the ball(线段树区间更新)
Color the ball 我真的该认真的复习一下以前没懂的知识了,今天看了一下线段树,以前只会用模板,现在看懂了之后,发现还有这么多巧妙的地方,好厉害啊 所以就应该尽量搞懂 弄明白每个知识点 [题 ...
- hihoCoder 1080 : 更为复杂的买卖房屋姿势 线段树区间更新
#1080 : 更为复杂的买卖房屋姿势 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi和小Ho都是游戏迷,“模拟都市”是他们非常喜欢的一个游戏,在这个游戏里面他们 ...
- hdu 3397 Sequence operation(线段树:区间更新)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3397 题意:给你一个长度为n的0,1序列,支持下列五种操作, 操作0(0 a b):将a到b这个区间的 ...
- 【HDU 4614】Vases and Flowers(线段树区间更新懒惰标记)
题目0到n-1的花瓶,操作1在下标a开始插b朵花,输出始末下标.操作2清空[a,b]的花瓶,求清除的花的数量.线段树懒惰标记来更新区间.操作1,先查询0到a-1有num个空瓶子,然后用线段树的性质,或 ...
- HDU 1698 Just a Hook(线段树/区间更新)
题目链接: 传送门 Minimum Inversion Number Time Limit: 1000MS Memory Limit: 32768 K Description In the g ...
- HDU 5023 A Corrupt Mayor's Performance Art(线段树区间更新)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5023 解题报告:一面墙长度为n,有N个单元,每个单元编号从1到n,墙的初始的颜色是2,一共有30种颜色 ...
- HDU 4902 Nice boat 2014杭电多校训练赛第四场F题(线段树区间更新)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4902 解题报告:输入一个序列,然后有q次操作,操作有两种,第一种是把区间 (l,r) 变成x,第二种是 ...
- hdu 1556:Color the ball(第二类树状数组 —— 区间更新,点求和)
Color the ball Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
随机推荐
- nyoj71--独木舟上的旅行
描述 进行一次独木舟的旅行活动,独木舟可以在港口租到,并且之间没有区别.一条独木舟最多只能乘坐两个人,且乘客的总重量不能超过独木舟的最大承载量.我们要尽量减少这次活动中的花销,所以要找出可以安置所有旅 ...
- Model Builder中Table2Table中字段映射的问题
ArcGIS10中使用过程中,Bug不少.尽管有了SP3,但模型耦合的深层次的应用中还是错误不少.目前只是遇到一个,利用躲避的方法解决一个.例如,从NetCDF中抽出的数据表,必须在内存和数据库中都存 ...
- exynos 4412 eMMC配置及使用方法
/** ****************************************************************************** * @author Maox ...
- 简单的jQuery获取URL的?后带的参数
var con_name = getQueryString("con_name"); //接收con_name function getQueryString(val ...
- jdbc 连接 mysql 获取 数据集 条数
package nona; import java.io.IOException; import java.io.PrintWriter; import java.sql.Connection; im ...
- Microsoft Azure Preview portal 以及Preview Features介绍
首先mooncake版本并不提供此类功能. 国际版会把将来推出的功能提供Preview,而且是免费的,有想研究未来技术以及的同学可以尝试 通过以下地址进入国际版,往下拉 http://azure.mi ...
- linux 获取cpu 个数
sysconf( )有unistd.h提供,要使用该函数需要#include<unistd.h>,其参数可以是_SC_NPROCESSORS_CONF,也可以是_SC_NPROCESSOR ...
- Oracle中的注释
注释用于对程序代码的解释说明,它能够增强程序的可读性,是程序易于理解. 单行注释: 用“--”,后面跟上注释的内容 Declare Num_sal number; --声明一个数字类型的变量 Var_ ...
- php protected只能被继承,不可以在实例中调用,parent::调用父类(子类函数的重载对父类的函数没有影响)
<?php class a { private function fun1(){ echo 'a1'; } //protected 可以被继承,但是只能在子类中使用,不能被实例化调用 prote ...
- POJ 2315 最小费用最大流
从1走到N然后从N走回来的最短路程是多少? 转换为费用流来建模. 1: /** 2: 因为e ==0 所以 pe[v] pe[v]^1 是两条相对应的边 3: E[pe[v]].c -= aug; E ...