洛谷P4588 [TJOI2018]数学计算 【线段树】
2018-05-17 12:31
330 查看
题目链接
题解
用线段树维护即可
#include<algorithm> #include<iostream> #include<cstring> #include<cstdio> #include<cmath> #include<map> #define Redge(u) for (int k = h[u],to; k; k = ed[k].nxt) #define REP(i,n) for (int i = 1; i <= (n); i++) #define mp(a,b) make_pair<int,int>(a,b) #define cls(s) memset(s,0,sizeof(s)) #define cp pair<int,int> #define LL long long int #define ls (u << 1) #define rs (u << 1 | 1) using namespace std; const int maxn = 100005,maxm = 100005,INF = 1000000000; inline LL read(){ LL out = 0,flag = 1; char c = getchar(); while (c < 48 || c > 57){if (c == '-') flag = -1; c = getchar();} while (c >= 48 && c <= 57){out = (out << 3) + (out << 1) + c - 48; c = getchar();} return out * flag; } int Q,P; LL val[maxn << 2]; void build(int u,int l,int r){ if (l == r){val[u] = 1; return;} int mid = l + r >> 1; build(ls,l,mid); build(rs,mid + 1,r); val[u] = 1ll * val[ls] * val[rs] % P; } void modify(int u,int l,int r,int pos,LL v){ if (l == r){val[u] = v; return;} int mid = l + r >> 1; if (mid >= pos) modify(ls,l,mid,pos,v); else modify(rs,mid + 1,r,pos,v); val[u] = 1ll * val[ls] * val[rs] % P; } LL query(int u,int l,int r,int L,int R){ if (l >= L && r <= R) return val[u]; int mid = l + r >> 1; if (mid >= R) return query(ls,l,mid,L,R); if (mid < L) return query(rs,mid + 1,r,L,R); return 1ll * query(ls,l,mid,L,R) * query(rs,mid + 1,r,L,R) % P; } int main(){ int T = read(); while (T--){ Q = read(); P = read(); LL opt,v; build(1,1,Q); REP(i,Q){ opt = read(); v = read(); if (opt & 1) modify(1,1,Q,i,v % P); else modify(1,1,Q,v,1); printf("%lld\n",query(1,1,Q,1,i)); } } return 0; }
相关文章推荐
- BZOJ5334 [TJOI2018] 数学计算 【线段树分治】
- BZOJ5334:[TJOI2018]数学计算——题解
- [BZOJ5334][TJOI2018]数学计算(exgcd/线段树)
- 洛谷P4593 [TJOI2018]教科书般的亵渎 【数学】
- Maple 2018 数学工程计算 Mac中文破解版
- 【漂浮法或线段树】 解决矩阵覆盖(计算几何)问题
- hdu 1466 计算直线的交点数 (数学)
- 计算出用字符串表示的数学表达式的值
- 调用 VBScript 计算简单的四则混合运算数学题
- 关于 2018 云计算的四个预测:Severless、K8S、边缘计算、神龙
- CF311D Interval Cubing 数学、线段树
- 「机器学习和大数据计算都是学数学应该干的,学计算机的相比毫无优势」
- ZOJ 3175 Number of Containers 【数学图像性质(一个常见算式的经典计算)】
- MySQL必知必会-9MySQL常用函数及数学计算
- 数学之路-python计算实战(12)-机器视觉-图像增强
- 【原创】开源Math.NET基础数学类库使用(02)矩阵向量计算
- Ubuntu系统技巧之在命令行进行数学计算
- math.h里的数学计算公式介绍
- 几个数学计算函数
- 【EI检索】第十四届无线通信、网络技术与移动计算国际学术会议(WiCOM 2018)