BZOJ 4499: 线性函数
4499: 线性函数
Time Limit: 20 Sec Memory Limit: 256 MB
Submit: 177 Solved: 127
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
4 2
3 6
5 7
2 6
7 5
Q 1 5 1
Q 3 3 2
M 3 10 6
Q 1 4 3
Q 3 4 4
Sample Output
17
978
98
HINT
1 <= n, m <= 200,000,0 <= k, b, x < 1000,000,007
Source
莫名其妙,线段树维护一下区间的函数和就好了,单点修改,区间查询,比GSS还水……
UPDATE 感觉这么水的题,再困还是可以写出来的,补代码……
#include<cstdio>
#define N 200005
#define M 800005
#define P 1000000007
int n,m,ki[N],bi[N],k[M],b[M];
void build(int t,int l,int r){
if(l==r)k[t]=ki[l],b[t]=bi[l];
else{
int d=l+r>>,x=t<<,y=x|;
build(x,l,d);
build(y,d+,r);
k[t]=(1LL*k[x]*k[y])%P;
b[t]=(1LL*k[y]*b[x]%P+b[y])%P;
}
}
void build(int t,int l,int r,int p){
if(l==r)k[t]=ki[l],b[t]=bi[l];
else{
int d=l+r>>,x=t<<,y=x|;
if(p<=d)build(x,l,d,p);
else build(y,d+,r,p);
k[t]=(1LL*k[x]*k[y])%P;
b[t]=(1LL*k[y]*b[x]%P+b[y])%P;
}
}
int query(int t,int l,int r,int x,int y,int v){
if(l==x&&r==y)return (1LL*k[t]*v%P+b[t])%P;
int d=l+r>>;
if(y<=d)return query(t<<,l,d,x,y,v);
if(x>d)return query(t<<|,d+,r,x,y,v);
return query(t<<|,d+,r,d+,y,query(t<<,l,d,x,d,v));
}
main(){
scanf("%d%d",&n,&m);
for(int i=;i<=n;++i)
scanf("%d%d",ki+i,bi+i);
build(,,n);
while(m--){
static int x,y,z;
static char s[];
scanf("%s%d%d%d",s,&x,&y,&z);
if(s[]=='M')ki[x]=y,bi[x]=z,build(,,n,x);
else printf("%d\n",query(,,n,x,y,z));
}
}
@Author: YouSiki
BZOJ 4499: 线性函数的更多相关文章
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- BZOJ 题目整理
bzoj 500题纪念 总结一发题目吧,挑几道题整理一下,(方便拖板子) 1039:每条线段与前一条线段之间的长度的比例和夹角不会因平移.旋转.放缩而改变,所以将每条轨迹改为比例和夹角的序列,复制一份 ...
- BZOJ 2127: happiness [最小割]
2127: happiness Time Limit: 51 Sec Memory Limit: 259 MBSubmit: 1815 Solved: 878[Submit][Status][Di ...
- BZOJ 3275: Number
3275: Number Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 874 Solved: 371[Submit][Status][Discus ...
- BZOJ 2879: [Noi2012]美食节
2879: [Noi2012]美食节 Time Limit: 10 Sec Memory Limit: 512 MBSubmit: 1834 Solved: 969[Submit][Status] ...
- bzoj 4610 Ceiling Functi
bzoj 4610 Ceiling Functi Description bzoj上的描述有问题 给出\(n\)个长度为\(k\)的数列,将每个数列构成一个二叉搜索树,问有多少颗形态不同的树. Inp ...
- 【sdoi2013】森林 BZOJ 3123
Input 第一行包含一个正整数testcase,表示当前测试数据的测试点编号.保证1≤testcase≤20. 第二行包含三个整数N,M,T,分别表示节点数.初始边数.操作数.第三行包含N个非负整数 ...
- 【清华集训】楼房重建 BZOJ 2957
Description 小A的楼房外有一大片施工工地,工地上有N栋待建的楼房.每天,这片工地上的房子拆了又建.建了又拆.他经常无聊地看着窗外发呆,数自己能够看到多少栋房子. 为了简化问题,我们考虑这些 ...
- 【splay】文艺平衡树 BZOJ 3223
Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列,其中需要提供以下操作:翻转一个区间,例如原有序序列是5 4 3 2 1,翻转区间是[2,4]的话,结果是5 2 3 ...
随机推荐
- TensorFlow框架下的RNN实践小结
截至目前,TensorFlow的RNN APIs还处于Draft阶段.不过据官方解释,RNN的相关API已经出现在Tutorials里了,大幅度的改动应该是不大可能,现在入手TF的RNN APIs风险 ...
- Quartz.Net分布式任务管理平台(第二版)
前言:在Quartz.Net项目发布第一版后,有挺多园友去下载使用,我们通过QQ去探讨,其中项目中还是存在一定的不完善.所以有了现在这个版本.这个版本的编写完成其实有段时间了一直没有放上去.现在已经同 ...
- Html5计算MD5值
教程: http://www.tuicool.com/articles/InEBNz 组件: https://github.com/satazor/js-spark-md5
- 分布式监控系统Zabbix--完整安装记录(7)-使用percona监控MySQL
前面已经介绍了分布式监控系统Zabbix-3.0.3-完整安装记录(2)-添加mysql监控,但是没有提供可以直接使用的Key,太过简陋,监控效果不佳.要想更加仔细的监控Mysql,业内同学们都会选择 ...
- left join 右表数据不唯一的情况解决方法
https://blog.csdn.net/u010089432/article/details/52165026
- Linux内核设计第十七章笔记
第十七章 设备与模块 关于设备驱动和设备管理,四种内核成分 设备类型:在所有unix系统中为了统一普通设备的操作所采用的分类 模块:Linux内核中用于按需加载和卸载目标代码的机制 内核对象:内核数据 ...
- let命令和块级作用域
学习了阮一峰老师的ES6,http://es6.ruanyifeng.com/,收益良多. 一.let命令1.概念:let命令用于声明变量,和var类似,但是使用let命令所声明的变量只有在该变量所在 ...
- 个人项目junit4测试
一.题目简介 用java编写一个程序,模拟ATM柜员机. 二.源码的github链接 www.github.com/liuxianchen/test 三.所设计的模块测试用例.测试结果截图 四 心得 ...
- 推广App篇
推广App篇 团队github地址:https://github.com/ouqifeng/EasyGoOperation.git 在完成该项目工程后,我们开始寻找合适的方法推广我们的软件. 经过一番 ...
- 【Alpha阶段】展示博客发布!
1.团队成员简介 Email:qianlxc@126.com Free time:8:00 7:00 a.m ~ 11:00 12:00p.m Introduction: 我是一个热情的人.开朗的人. ...