Problem Description
Yuanfang is puzzled with the question below:
There
are n integers, a1, a2, …, an. The initial
values of them are 0. There are four kinds of operations.
Operation 1: Add c
to each number between ax and ay inclusive. In other
words, do transformation ak<---ak+c, k =
x,x+1,…,y.
Operation 2: Multiply c to each number between ax and
ay inclusive. In other words, do transformation
ak<---ak×c, k = x,x+1,…,y.
Operation 3: Change the
numbers between ax and ay to c, inclusive. In other words,
do transformation ak<---c, k = x,x+1,…,y.
Operation 4: Get the
sum of p power among the numbers between ax and ay
inclusive. In other words, get the result of
axp+ax+1p+…+ay
p.
Yuanfang has no idea of how to do it. So he wants to ask you to
help him. 
                                                         --by HDUoj
http://acm.hdu.edu.cn/showproblem.php?pid=4578


因为p<4,所以,直接线段树维护区间和,平方和,立方和,三棵树,打上乘法,加法,更改标记,注意down的顺序;
所以,会线段树的话,这题主要考代码能力......和信仰。
记得及时取模。
代码如下:
 #include<cstdio>
#define mod 10007
using namespace std; long long tree[][];
long long mark1[],mark2[],mark3[]; int n,m,L,R;
long long a,b; void work();
void build(int ,int ,int );
void up(int );
void down(int ,int ,int );
void change(int ,int ,int );
long long sum(int ,int ,int ); int main()
{
while()
{
scanf("%d%d",&n,&m);
if(n==&&m==)
return ;
work();
}
} void work()
{
int i;
long long ans=;
build(,n,);
for(i=;i<=m;i++)
{
scanf("%d%d%d%d",&b,&L,&R,&a);
if(b==)
{
ans=sum(,n,);
printf("%lld\n",ans%mod);
}
else
change(,n,);
}
} void build(int l,int r,int nu)
{
tree[][nu]=tree[][nu]=tree[][nu]=mark1[nu]=mark3[nu]=;
mark2[nu]=;
if(l==r)
return ;
int mid=(l+r)>>;
build(l,mid,nu<<);
build(mid+,r,nu<<|);
} void up(int nu)
{
tree[][nu]=(tree[][nu<<]+tree[][nu<<|])%mod;
tree[][nu]=(tree[][nu<<]+tree[][nu<<|])%mod;
tree[][nu]=(tree[][nu<<]+tree[][nu<<|])%mod;
} void down(int l,int r,int nu)
{
int mid=(l+r)>>;
if(mark3[nu])
{
tree[][nu<<]=tree[][nu<<]=tree[][nu<<]=;
mark1[nu<<]=;mark2[nu<<]=;
mark3[nu<<]=mark3[nu];
tree[][nu<<|]=tree[][nu<<|]=tree[][nu<<|]=;
mark1[nu<<|]=;mark2[nu<<|]=;
mark3[nu<<|]=mark3[nu];
}
tree[][nu<<]=(tree[][nu<<]*mark2[nu]*mark2[nu]*mark2[nu])%mod;
tree[][nu<<]=(tree[][nu<<]*mark2[nu]*mark2[nu])%mod;
tree[][nu<<]=(tree[][nu<<]*mark2[nu])%mod;
tree[][nu<<]=(tree[][nu<<]+*tree[][nu<<]*mark1[nu]+*tree[][nu<<]*mark1[nu]*mark1[nu]+(mid-l+)*mark1[nu]*mark1[nu]*mark1[nu])%mod;
tree[][nu<<]=(tree[][nu<<]+*mark1[nu]*tree[][nu<<]+(mid-l+)*mark1[nu]*mark1[nu])%mod;
tree[][nu<<]=(tree[][nu<<]+mark1[nu]*(mid-l+))%mod;
mark2[nu<<]=(mark2[nu<<]*mark2[nu])%mod;
mark1[nu<<]=(mark1[nu<<]*mark2[nu]+mark1[nu])%mod;
tree[][nu<<|]=(tree[][nu<<|]*mark2[nu]*mark2[nu]*mark2[nu])%mod;
tree[][nu<<|]=(tree[][nu<<|]*mark2[nu]*mark2[nu])%mod;
tree[][nu<<|]=(tree[][nu<<|]*mark2[nu])%mod;
tree[][nu<<|]=(tree[][nu<<|]+*tree[][nu<<|]*mark1[nu]+*tree[][nu<<|]*mark1[nu]*mark1[nu]+(r-mid)*mark1[nu]*mark1[nu]*mark1[nu])%mod;
tree[][nu<<|]=(tree[][nu<<|]+*mark1[nu]*tree[][nu<<|]+(r-mid)*mark1[nu]*mark1[nu])%mod;
tree[][nu<<|]=(tree[][nu<<|]+mark1[nu]*(r-mid))%mod;
mark2[nu<<|]=(mark2[nu<<|]*mark2[nu])%mod;
mark1[nu<<|]=(mark1[nu<<|]*mark2[nu]+mark1[nu])%mod;
mark1[nu]=mark3[nu]=;mark2[nu]=;
} void change(int l,int r,int nu)
{
if(L<=l&&r<=R)
{
if(b==)
{
mark1[nu]=a;
mark2[nu]=;
mark3[nu]=;
tree[][nu]=a*(r-l+)%mod;
tree[][nu]=(a*a*(r-l+))%mod;
tree[][nu]=(a*a*a*(r-l+))%mod;
}
if(b==)
{
mark1[nu]=(mark1[nu]*a)%mod;
mark2[nu]=(mark2[nu]*a)%mod;
tree[][nu]=(tree[][nu]*a)%mod;
tree[][nu]=(tree[][nu]*a*a)%mod;
tree[][nu]=(tree[][nu]*a*a*a)%mod;
}
if(b==)
{
mark1[nu]=(mark1[nu]+a)%mod;
tree[][nu]=(tree[][nu]+*tree[][nu]*a+*tree[][nu]*a*a+(r-l+)*a*a*a)%mod;
tree[][nu]=(tree[][nu]+*a*tree[][nu]+(r-l+)*a*a)%mod;
tree[][nu]=(tree[][nu]+a*(r-l+))%mod;
}
return;
}
down(l,r,nu);
int mid=(l+r)>>;
if(L<=mid)
change(l,mid,nu<<);
if(R>=mid+)
change(mid+,r,nu<<|);
up(nu);
} long long sum(int l,int r,int nu)
{
long long su=;
if(L<=l&&r<=R)
return tree[a][nu];
down(l,r,nu);
int mid=(l+r)>>;
if(L<=mid)
su+=sum(l,mid,nu<<);
if(R>=mid+)
su+=sum(mid+,r,nu<<|);
su=su%mod;
return su;
}
祝AC哟;

HDU P4578 Transformation的更多相关文章

  1. HDU 4578 - Transformation - [加强版线段树]

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4578 Problem Description Yuanfang is puzzled with the ...

  2. HDU 4578 Transformation (线段树区间多种更新)

    http://acm.hdu.edu.cn/showproblem.php?pid=4578 题目大意:对于一个给定序列,序列内所有数的初始值为0,有4种操作.1:区间(x, y)内的所有数字全部加上 ...

  3. hdu 4578 Transformation

    http://acm.hdu.edu.cn/showproblem.php?pid=4578 题意:1,a,b,c代表在a,b区间的每一个数加上c:2,a,b,c代表在a,b区间的每一个数乘上c: 3 ...

  4. HDU 4578 Transformation (线段树)

    Transformation Time Limit: 15000/8000 MS (Java/Others)    Memory Limit: 65535/65536 K (Java/Others)T ...

  5. HDU 4578——Transformation——————【线段树区间操作、确定操作顺序】

    Transformation Time Limit: 15000/8000 MS (Java/Others)    Memory Limit: 65535/65536 K (Java/Others)T ...

  6. Hdu 4578 Transformation (线段树 分类分析)

    Transformation Time Limit: 15000/8000 MS (Java/Others)    Memory Limit: 65535/65536 K (Java/Others)T ...

  7. HDU 4578 Transformation --线段树,好题

    题意: 给一个序列,初始全为0,然后有4种操作: 1. 给区间[L,R]所有值+c 2.给区间[L,R]所有值乘c 3.设置区间[L,R]所有值为c 4.查询[L,R]的p次方和(1<=p< ...

  8. hdu 4578 Transformation 线段树

    没什么说的裸线段树,注意细节就好了!!! 代码如下: #include<iostream> #include<stdio.h> #include<algorithm> ...

  9. hdu 4578 Transformation(线段树)

    线段树上的多操作... 题目大意: 树上 的初始值为0,然后有下列三种操作和求和. 1  x y c  在X-Y的之间全部加上C. 2  x y c  在X-Y的之间全部乘上C. 3  x y c   ...

随机推荐

  1. BZOJ 1596: [Usaco2008 Jan]电话网络

    Description Farmer John决定为他的所有奶牛都配备手机,以此鼓励她们互相交流.不过,为此FJ必须在奶牛们居住的N(1 <= N <= 10,000)块草地中选一些建上无 ...

  2. C语言预处理运算符

    转自C语言预处理运算符 预处理还需要运算符?有没有搞错? ^_^, 没有搞错,预处理是有运算符,而且还不止一个: #(单井号)    -- 字符串化运算符. ##(双井号 )-- 连接运算符 #@   ...

  3. C#语法中一个问号(?)和两个问号(??)的运算符是什么意思?

    (1).C#语法中一个个问号(?)的运算符是指:可以为 null 的类型. MSDN上面的解释: 在处理数据库和其他包含不可赋值的元素的数据类型时,将 null 赋值给数值类型或布尔型以及日期类型的功 ...

  4. C++如何处理内联虚函数

    http://blog.csdn.net/hedylin/article/details/1775556 当一个函数是内联和虚函数时,会发生代码替换或使用虚表调用吗? 为了弄清楚内联和虚函数,让我们将 ...

  5. Ubuntu zookeeper-3.5.0-alpha启动错误 zkEnv.sh: Syntax error: "(" unexpected (expecting "fi")(转)

    昨天小猿我把Ubuntu Server64位上的 zookeeper换成了最新版本的,结果启动的时候出错:之前zookeeper-3.3.6是没有任何问题的,换成了zookeeper3.5出现了下面的 ...

  6. crtmpserver系列之一:流媒体概述

    阅读目录 概述 流媒体系统的组成 媒体文件封装 传输协议 回到顶部 概述 所谓流媒体按照字面意思理解就是像流一样的媒体,看起来像是废话.流媒体现在司空见惯,所以一般人大概不会有疑问.事实上在流媒体还没 ...

  7. !!对python列表学习整理列表及数组详细介绍

    1.Python的数组分三种类型:(详细见 http://blog.sina.com.cn/s/blog_6b783cbd0100q2ba.html) (1) list 普通的链表,初始化后可以通过特 ...

  8. 【HDOJ】1356 The Balance

    扩展欧几里得的应用. /* 1356 */ #include <iostream> #include <sstream> #include <string> #in ...

  9. Eclipse设置、问题解决方案

    Eclipse设置: 1.如何把eclipse关闭提示调出来? 可以这样打开这个提示:选择 Windows --Preferences,在左边树上选择“General” --“Startup and ...

  10. mac 修改密码后 频繁输入钥匙串问题修复方法

    就一句话就是 清空钥匙串缓存 下面是具体方法 进入硬盘目录-->资源库-->Keychains 删除里面的文件夹(这个文件夹里面有 keychain-2.db keychain-2.db- ...