[洛谷3934]P3934 Nephren Ruq Insania题解
先放个奈芙莲
解法
看到这种题目就知道是欧拉降幂,然后根据某玄学证明,递归欧拉降幂从l到r不会超过\(\Theta(log_n)\),所以直接递归解决,然后区间修改直接树状数组维护一下
然后就A了
代码
#include <cstdio>
namespace FenTree{
#define lowbit(x) (x&(-x))
#define MAXN 500005
#define ll long long
ll BIT[MAXN]; int n;
void add(int pos, int val){
for (; pos <= n; pos += lowbit(pos)) BIT[pos] += val;
}
ll query(int pos){
ll sum = 0;
for (; pos; pos -= lowbit(pos)) sum += BIT[pos];
return sum;
}
void addsec(int l, int r, int val){
add(l, val);
if (r < n) add(r + 1, -val);
}
#undef ll
#undef MAXN
#undef lowbit
};
namespace IO{
#define ll long long
inline ll read(){
ll x = 0; int zf = 1; char ch = ' ';
while (ch != '-' && (ch < '0' || ch > '9')) ch = getchar();
if (ch == '-') zf = -1, ch = getchar();
while (ch >= '0' && ch <= '9') x = x * 10 + ch - '0', ch = getchar(); return x * zf;
}
#undef ll
};
namespace Qpow{
#define ll long long
ll pow(ll a, ll b, ll mod){
if (!a) return 0;
ll ans = 1;
for ( ; b; b >>= 1, a = (a * a) % mod)
if (b & 1)
ans *= a, ans %= mod;
return ans;
}
ll elrPow(ll x, ll y, ll mod){
ll res = 1; bool flgres = 0, flgx = 0;
for ( ; y; y >>= 1){
if (y & 1){
res *= x, flgres = flgx;
if (res >= mod) res %= mod, flgres = 1;
}
if (x >= mod)flgx = 1, x %= mod;
x *= x;
if (x >= mod)flgx = 1, x %= mod;
}
return flgres ? (res + mod) : res;
}
#undef ll
}
int phi[20000005];
int primes[20000005], pcnt;
bool isnp[20000005];
void getPhi(int num){
phi[1] = 1;
for (int i = 2; i <= num; ++i){
if (!isnp[i]) primes[++pcnt] = i, phi[i] = i - 1;
for (int j = 1; j <= pcnt && i * primes[j] <= num; ++j){
isnp[i * primes[j]] = 1;
if (!(i % primes[j])){phi[i * primes[j]] = phi[i] * primes[j]; break;}
phi[i * primes[j]] = phi[i] * (primes[j] - 1);
}
}
}
int a[500005];
long long solve(int l, int r, long long p){
if (p == 1 || l > r) return 1;
long long x = FenTree::query(l) + a[l];
return Qpow::elrPow(x, solve(l + 1, r, phi[p]), p);
}
int main(){
getPhi(20000000);
int n = IO::read(), m = IO::read(); FenTree::n = n;
for (int i = 1; i <= n; ++i) a[i] = IO::read();
int op, l, r; long long val;
for (int i = 1; i <= m; ++i){
op = IO::read(), l = IO::read(), r = IO::read(), val = IO::read();
if (op == 1) FenTree::addsec(l, r, val);
else printf("%lld\n", solve(l, r, val) % val);
}
return 0;
}
[洛谷3934]P3934 Nephren Ruq Insania题解的更多相关文章
- 洛谷3934:Nephren Ruq Insania——题解
https://www.luogu.org/problemnew/show/P3934 题面自己读吧(滑稽. 看到这道题就能够想到BZOJ4869:[SHOI2017]相逢是问候我们曾经用过的哲学扩展 ...
- [洛谷P4118][Ynoi2016]炸脖龙I([洛谷P3934]Nephren Ruq Insania)
题目大意:有$n$个数,每个数为$s_i$,两个操作: $1\;l\;r\;x:$表示将区间$[l,r]$内的数加上$x$ $2\;l\;r\;p:$表示求$s_l^{s_{l+1}^{^{s_{l+ ...
- 洛谷P1854 花店橱窗布置 分析+题解代码
洛谷P1854 花店橱窗布置 分析+题解代码 蒟蒻的第一道提高+/省选-,纪念一下. 题目描述: 某花店现有F束花,每一束花的品种都不一样,同时至少有同样数量的花瓶,被按顺序摆成一行,花瓶的位置是固定 ...
- HAOI2006 (洛谷P2341)受欢迎的牛 题解
HAOI2006 (洛谷P2341)受欢迎的牛 题解 题目描述 友情链接原题 每头奶牛都梦想成为牛棚里的明星.被所有奶牛喜欢的奶牛就是一头明星奶牛.所有奶 牛都是自恋狂,每头奶牛总是喜欢自己的.奶牛之 ...
- 洛谷P3412 仓鼠找$Sugar\ II$题解(期望+统计论?)
洛谷P3412 仓鼠找\(Sugar\ II\)题解(期望+统计论?) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1327573 原题链接:洛谷P3412 ...
- 洛谷P3502 [POI2010]CHO-Hamsters感想及题解(图论+字符串+矩阵加速$dp\&Floyd$)
洛谷P3502 [POI2010]CHO-Hamsters感想及题解(图论+字符串+矩阵加速\(dp\&Floyd\)) 标签:题解 阅读体验:https://zybuluo.com/Junl ...
- BZOJ4946 & 洛谷3826 & UOJ318:[NOI2017]蔬菜——题解
https://www.lydsy.com/JudgeOnline/problem.php?id=4946 https://www.luogu.org/problemnew/show/P3826 ht ...
- 洛谷1578:[WC2002]奶牛浴场——题解
https://www.luogu.org/problemnew/show/P1578#sub 由于John建造了牛场围栏,激起了奶牛的愤怒,奶牛的产奶量急剧减少.为了讨好奶牛,John决定在牛场中建 ...
- 洛谷P2460 [SDOI2007]科比的比赛(题解)(贪心+搜索)
科比的比赛(题解)(贪心+搜索) 标签:算法--贪心 阅读体验:https://zybuluo.com/Junlier/note/1301158 贪心+搜索 洛谷题目:P2460 [SDOI2007] ...
随机推荐
- echars 柱状图正常状态 --》二次封装
<template> <!-- 柱状图 正常 1. 调用页面引入 import EcharsColumnNormal from '@/components/echarsColumnN ...
- [Web 前端] 029 jQuery 元素的“节操”
目录 jQuery 元素的节点操作 1. 创建节点 2. 插入节点 2.1 在现存元素的内部,从后面插入元素 2.2 在现存元素的内部,从前面插入元素 2.3 在现存元素的外部,从后面插入元素 2.4 ...
- 极*Java速成教程 - (7)
Java高级特性 数组 在Java中,数组是一串连续的,不可改变长度的,对象被固定的,类型固定的连续空间.数组中的随机访问非常迅速,但为了速度放弃了灵活性.而效率也是数组最大的优点. 在使用泛型的容器 ...
- 网络流 ISAP算法
网络流问题: 我自己理解,在流网络中,在不违背容量限制的条件下,解决各种从源点到汇点的问题. ISAP算法概念: 据说不会有卡ISAP时间的题目---时间复杂度O(E^2*V) 首先原理都是基于不断寻 ...
- Python 入门之代码块、小数据池 与 深浅拷贝
Python 入门之代码块.小数据池 与 深浅拷贝 1.代码块 (1)一个py文件,一个函数,一个模块,终端中的每一行都是代码块 (代码块是防止我们频繁的开空间降低效率设计的,当我们定一个变量需要开辟 ...
- 什么是lambda函数?有什么好处?
lambda 函数是一个可以接收任意多个参数(包括可选参数)并且返回单个表达式值的匿名函数 好处:1.lambda 函数比较轻便,即用即删除,很适合需要完成一项功能,但是此功能只在此一处使用,连名字都 ...
- NOI-LINUX
先把配置背过吧: (set-background-color "gray15")(set-foreground-color "gray")(global-lin ...
- 说说 HeapSort 堆排序思想,以及个人优化方案。(老物)
听说你要排上亿个数据之 HeapSort ? 前言 : 来来来,今天我们来说说一个用来排大量数据所用的基础比较排序吧~ 注:阅读本文学习新技能的前置要求为:了解什么是二叉树及其数组性质,如果未达到要求 ...
- C++实现简单的日志记录
C++实现简单的日志记录 //dlogger.h #ifndef DLOGGER_H #define DLOGGER_H #include <iostream> #include < ...
- ambari 2.5.0源码编译安装
参考:https://www.ibm.com/developerworks/cn/opensource/os-cn-bigdata-ambari/index.html Ambari 是什么 Ambar ...