hdu-4893
http://acm.hdu.edu.cn/showproblem.php?pid=1394
题意:
给定一个数组a,一开始数组里面的元素都是0,现在有三个操作:
操作1:给第k个数字加上d.
操作2:查询区间[l,r]的和.
操作3:改变区间[l,r]的每个数为最接近的斐波那契数列.其中斐波那契数列的f0=1,f1=1.
题解:
这题是单点更新+区间求和+区间更新,我们知道区间求和为了节省一点时间用的是懒惰标记来给每个被更改过的区间打上标记,而当我们需要计算这个区间的时候才将标记下推,使得值更新.
所以对于操作1的话,当我们更新单点的值得时候,由于当前区间在之前可能经历过区间的更改,所以我们需要维护两个数组来.第一个数组sum1用来维护所需要的输出的和,第二个数组sum2用来维护的是经过操作3之后的当前区间的和.
所以对于操作1的时候,需要判断一下该点有没有懒惰标记,如果有的话,该点的值用的就是经过操作3的sum2的值来更改,否则直接更改sum1的值.
AC代码:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
int dir[][]={{,},{,},{,},{,-},{-,},{-,-},{,-},{-,}};
#define pi acos(-1)
#define ls rt<<1
#define rs rt<<1|1
#define me0(s) memset(s,0,sizeof(s))
#define me1(s) memset(s,1,sizeof(s))
#define mef(s) memset(s,-1,sizeof(s))
#define meinf(s) memset(s,inf,sizeof(s))
#define llinf 1e18
#define inf 1e9
const int N=1e5+;
ll fab[N];
int n,m;
ll lazy[N*]; //lazy表示该区间的数要更改为斐波那契
ll a[N],sum1[N*],sum2[N*];//sum1表示原来的和,sum2表示更改后的值
void init(){
fab[]=fab[]=;
for(int i=;i<=;i++){
fab[i]=fab[i-]+fab[i-];
}
}
ll find_fab(ll x){
ll ans=fab[];
ll c=abs(fab[]-x);
for(int i=;i<=;i++){
if(abs(x-fab[i])<c){
c=abs(x-fab[i]);
ans=fab[i];
}
}
return ans;
}
void pushup(int rt){
sum1[rt]=sum1[ls]+sum1[rs];
sum2[rt]=sum2[ls]+sum2[rs];
}
void pushdown(int rt){
if(lazy[rt]){
lazy[ls]=lazy[rs]=lazy[rt];
lazy[rt]=;
sum1[ls]=sum2[ls];
sum1[rs]=sum2[rs];
}
}
void build(int l,int r,int rt){
if(l==r){
sum2[rt]=;//初始状态所有数据为0,距离0最近的菲波那切数是1
return ;
}
int m=(l+r)/;
build(l,m,ls);
build(m+,r,rs);
pushup(rt);
}
void update1(int l,int r,int p,int c,int rt){
if(l==r){
if(lazy[rt]) sum1[rt]=sum2[rt]+c;
else sum1[rt]+=c;
sum2[rt]=find_fab(sum1[rt]);//更新sum1,sum2也要改变
lazy[rt]=;
return ;
}
pushdown(rt);
int m=(l+r)/;
if(p<=m) update1(l,m,p,c,ls);
if(p>m) update1(m+,r,p,c,rs);
pushup(rt);
}
void update2(int L,int R,int l,int r,int rt){
if(L<=l&&R>=r){
sum1[rt]=sum2[rt];
lazy[rt]=;
return ;
}
pushdown(rt);
int m=(l+r)/;
if(L<=m) update2(L,R,l,m,ls);
if(R>m) update2(L,R,m+,r,rs);
pushup(rt);
}
ll query(int L,int R,int l,int r,int rt){
if(L<=l&&R>=r){
return sum1[rt];
}
pushdown(rt);
int m=(l+r)/;
ll ans=;
if(L<=m) ans+=query(L,R,l,m,ls);
if(R>m) ans+=query(L,R,m+,r,rs);
return ans;
}
int main(int argc, char * argv[]){
init();
while(scanf("%d%d",&n,&m)!=EOF){
me0(sum1);
me0(lazy);
build(,n,);
while(m--){
int op,l,r;
scanf("%d%d%d",&op,&l,&r);
if(op==){
update1(,n,l,r,);
}
else if(op==){
printf("%lld\n",query(l,r,,n,));
}
else{
update2(l,r,,n,);
}
}
}
return ;
}
hdu-4893的更多相关文章
- 2014联合三所学校 (HDU 4888 HDU 4891 HDU 4893)
HDU 4891 The Great Pan 注册标题 他怎么说,你怎么样 需要注意的是乘法时,它会爆炸int 代码: #include<iostream> #include<c ...
- HDU 4893 Wow! Such Sequence! (线段树)
Wow! Such Sequence! 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4893 Description Recently, Doge ...
- hdu 4893 Wow! Such Sequence!
http://acm.hdu.edu.cn/showproblem.php?pid=4893 三种操作: 1 k d - "add" 2 l r - "query sum ...
- HDU 4893 线段树的 点更新 区间求和
Wow! Such Sequence! Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Oth ...
- hdu 4893 Wow! Such Sequence!(线段树)
题目链接:hdu 4983 Wow! Such Sequence! 题目大意:就是三种操作 1 k d, 改动k的为值添加d 2 l r, 查询l到r的区间和 3 l r. 间l到r区间上的所以数变成 ...
- HDU 4893 Wow! Such Sequence!(2014 Multi-University Training Contest 3)
题意: 有三种操作: 1 x y: 表示给x位置加上y 2 x y:查询[x,y]的区间和 3 x y:将 [x,y] 区间上的数变为最接近的 Fibonacci. 思路: 1 操作按正常单调更新,区 ...
- HDU 4893 线段树
比赛时太大意,斐波拉契数列开小了. 题目大意:1个序列,3种操作,改变序列某个数大小,将序列中连续的一段每个数都变成其最近的斐波拉契数,以及查询序列中某一段的数之和. 解题思路:维护add[]数组表示 ...
- HDU 4893 Wow! Such Sequence!(2014年多校联合 第三场 G)(线段树)
磨了一天的线段树,不能说完全搞清楚,只能说有一个大概的了解,靠着模板才把这道题A了,只能说太弱~~! 题意: 初始时有一字符串,全为0. 三种操作: 1 k d - add 把d加到第k个数上去2 ...
- 线段树 + 区间更新: HDU 4893 Wow! Such Sequence!
Wow! Such Sequence! Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Oth ...
- HDU 4893 Wow! Such Sequence! (树状数组)
题意:给有三种操作,一种是 1 k d,把第 k 个数加d,第二种是2 l r,查询区间 l, r的和,第三种是 3 l r,把区间 l,r 的所有数都变成离它最近的Fib数, 并且是最小的那个. 析 ...
随机推荐
- map方法的简单使用
假设有一个数组a,将a中的数值以2倍的形式放到b数组中 <!DOCTYPE html> <html lang="en"> <head> < ...
- Foxmail公司邮箱配置
1.打开Foxmail点击新建输入账户密码,点击创建: 2.勾选IMAP服务器的ssl,修改SMTP服务器端口为587 点击应用,账号创建完成.可以拉取和发送邮件了:
- 解决 php artisan route:list 报错oauth-private.key文件不存在或不可读的
进入项目根目录命令行执行 php artisan passport:install 然后执行php artisan route:list,会提示 Class App\Http\Controllers\ ...
- 【SQL】ON DUPLICATE KEY UPDATE
在实际应用中,经常碰到导入数据的功能,当导入的数据不存在时则进行添加,有修改时则进行更新, 在刚碰到的时候,第一反应是将其实现分为两块,分别是判断增加,判断更新,后来发现在mysql中有 ON DUP ...
- 云栖干货回顾 | 云原生数据库POLARDB专场“硬核”解析
POLARDB是阿里巴巴自主研发的云原生关系型数据库,目前兼容三种数据库引擎:MySQL.PostgreSQL.Oracle.POLARDB的计算能力最高可扩展至1000核以上,存储容量可达100TB ...
- java.lang.InstantiationException: com.lch.commder.entity.Car 已解决
以上的上异常,是你的类实例化对象失败的时候抛出异常,这种异常多会出现在抽象类中,在使用反射的机制时,解决方法很简单 在你的类中再加一个空构造方法
- Vue实现一个学生信息录入系统,实现录入和删除
效果如下: 代码如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset=&qu ...
- 兼容火狐浏览器的select下拉框样式
经常遇到这样的问题,在使用bootstrap框架的时候select选择框的样式在火狐浏览器上继承的是浏览器本身的样式,跟谷歌等其他的浏览器样式对比很难看,并且很难调整,但是! 好东西来了,现在能调成跟 ...
- flutter 显示base64 图片
后台返回base64 为了本地显示需要转换成Uint8List 1.导入包 import 'dart:convert';2.后台返回base64 格式不被识别需要切分 //'"data:im ...
- jeecg下实现自动默认模糊查询
也许jeecg的作者深受SAP毒害吧,没考虑到广大使用JEECG的人群为SAP用户,及所开发的项目均为中小项目,无惧大数据模糊查询带来的功能影响. 经网友“&&康&&& ...