P3934-Nephren Ruq Insania【欧拉定理,树状数组】

正题

题目链接:https://www.luogu.org/problemnew/show/P3934


题目大意

长度为nnn的序列aaa

  1. 1lrw:1\ l\ r\ w:1 l r w:l∼rl\sim rlr这个区间增加www
  2. 2lrp:2\ l\ r\ p:2 l r p:alal+1al+2...%pa_l^{a_{l+1}^{a_{l+2}^{...}}}\% palal+1al+2...%p直到ara_rar

解题思路

根据欧拉定理
ab%p={ab(b&lt;φ(p))ab%φ(p)+φ(p)(b≥φ(p))a^b\%p=\left\{\begin{matrix} a^b(b&lt;\varphi(p)) \\ a^{b\%\varphi(p)+\varphi(p)}(b\geq \varphi(p)) \\ \end{matrix}\right.ab%p={ab(b<φ(p))ab%φ(p)+φ(p)(bφ(p))
所以我们可以使用递推求询问,然后因为有两种情况所以我们需要开一个结构体储存值和是否需要+φ(p)+\varphi(p)+φ(p)。然后我们可以发现这样子不断递推下去,最多推到log(p)log(p)log(p)层左右即可退出

也就是φ(φ(φ(φ(φ(φ(...φ(p)))))))\varphi(\varphi(\varphi(\varphi(\varphi(\varphi(...\varphi(p)))))))φ(φ(φ(φ(φ(φ(...φ(p)))))))这样子下去最多log(p)log(p)log(p)层左右φ\varphiφ就为1了,因为任何数%1=0\% 1=0%1=0所以再往后已经没有必要了,所以询问的时间复杂度是log(p)log(p)log(p)层左右就结束了。

修改的话用树状数组维护就可以了。


codecodecode

#include<cstdio>
#include<cstring>
#include<algorithm>
#define lobit(x) (x&-x)
#define ll long long
using namespace std;
const ll N=501000,M=20000000;
ll n,cnt,m,t[N],phi[M+100],pr[M+100];
bool v[M+100];
struct node{ll w,flag;node(ll _w=0,ll _flag=0){w=_w;flag=_flag;}
};
void change(ll x,ll z)
{while(x<=n){t[x]+=z;x+=lobit(x);}
}
ll ask(ll x)
{ll sum=0;while(x){sum+=t[x];x-=lobit(x);}return sum;
}
void updata(ll l,ll r,ll x)
{change(l,x);change(r+1,-x);
}
void Get_phi()
{phi[1]=1;for(ll i=2;i<=20000000;i++){if(!v[i]){pr[++cnt]=i;phi[i]=i-1;}for(ll j=1;j<=cnt;j++){ll t=i*pr[j];if(t>20000000) break;v[t]=1;if(i%pr[j]==0){phi[t]=phi[i]*pr[j];break;}phi[t]=phi[i]*(pr[j]-1);}}
}
node power(ll x,ll b,ll p)
{node ans=node(1,0);if(x>=p){x%=p;ans.flag=1;}while(b){if(b&1) ans.w=ans.w*x;if(ans.w>=p){ans.w%=p;ans.flag=1;}x=x*x;b>>=1;if(x>=p){ans.flag=1;x%=p;}}return ans;
}
node solve(ll l,ll r,ll p)
{ll w=ask(l);node ans;if(p==1) return node(0,1);if(w==1) return node(1,0);if(l==r) return w<p?node(w,0):node(w%p,1);ans=solve(l+1,r,phi[p]);if(ans.flag) ans.w+=phi[p];return power(w,ans.w,p);
}
int main()
{Get_phi();scanf("%lld%lld",&n,&m);for(ll i=1;i<=n;i++){ll w;scanf("%lld",&w);updata(i,i,w);}for(ll i=1;i<=m;i++){ll op,l,r,w;scanf("%lld%lld%lld%lld",&op,&l,&r,&w);if(op==1) updata(l,r,w);else{node ans=solve(l,r,w);printf("%lld\n",ans.w);}}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/322256.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Entity Framework Core 懒加载

众所周知在EF 6 及以前的版本中&#xff0c;是支持懒加载&#xff08;Lazy Loading&#xff09;的&#xff0c;可惜在EF Core 并不支持&#xff0c;必须使用Include方法来支持导航属性的数据加载。不过现在EF Core的开发团队打算恢复对这一功能的支持&#xff08;目前还未发布&…

Sentinel(十六)之AHAS Sentinel 控制台

转载自 AHAS Sentinel 控制台 AHAS Sentinel 是 Sentinel 的阿里云上版本&#xff0c;提供企业级的高可用防护服务&#xff0c;包括&#xff1a; 可靠的实时监控和历史秒级监控数据查询&#xff0c;包含 QPS、RT、load、CPU 使用率等指标&#xff0c;支持按照调用类型分类&a…

和各路巨佬の随机挑战3总结

第三次挑战\huge \texttt{\color{purple}第\color{blue}三\color{green}次\color{block}挑\color{red}战}第三次挑战 规则 随机挑取一蓝一紫一黑来做&#xff0c;拥有两次换题机会&#xff0c;若黑题是暂未学过的算法可以拥有无限次换题机会。 van♂van♂van♂成记录 过程 晚…

浅析Entity Framework Core2.0的日志记录与动态查询条件

一、 Entity Framework Core2.0的日志记录早在Entity Framework Core1.0 ,我们就使用相关的ILoggerProvider ILogger 这些基础接口类.来实现过日志记录.在Entity Framework Core2.0 估计是为了配合ASP.NET Core的日志.所以对这些接口进行了更进一步的包装,也弃用了一些接口和类…

Sentinel(十七)之启动配置项

转载自 启动配置项 配置方式 Sentinel 提供如下的配置方式&#xff1a; JVM -D 参数方式properties 文件方式&#xff08;1.7.0 版本开始支持&#xff09; 其中&#xff0c;project.name 参数只能通过 JVM -D 参数方式配置&#xff08;since 1.8.0 取消该限制&#xff09;&…

jzoj3337-[NOI2013模拟]wyl8899的TLE【字符串hash,二分】

正题 题目大意 两个字符串A,BA,BA,B。可以修改AAA中的一个字符使得AAA中的1∼k1\sim k1∼k是BBB的子串&#xff0c;求kkk的最大值。 解题思路 先将AAA和BBB字符串hashhashhash&#xff0c;然后枚举BBB作为子串的起始位置&#xff0c;然后二分出不修改字符的第一个不相等处xxx…

Actor-ES框架:Ray--事件(Event)编写说明

Event作用&#xff1a;存储事件数据。IEventBaseK&#xff1a;是Actor的StateId的类型&#xff0c;可以是long、可以是string&#xff0c;Ray一般使用OGuid生成的字符串作为主键。编写Event继承IEventBase接口&#xff0c;Base部分如下&#xff1a; public string Id {…

Sentinel(十八)之注解支持

转载自 注解支持 Sentinel 提供了 SentinelResource 注解用于定义资源&#xff0c;并提供了 AspectJ 的扩展用于自动定义资源、处理 BlockException等。使用 Sentinel Annotation AspectJ Extension 的时候需要引入以下依赖&#xff1a; <dependency><groupId>c…

jzoj3338-[NOI2013模拟]法法塔的奖励【权值线段树,线段树合并】

正题 题目大意 一棵树&#xff0c;对于每个点&#xff0c;求从任何一个在该点的子树为头&#xff0c;以该点为结尾的序列必须选择这个点的最长不降子序列。 解题思路 首先我们使用权值线段树计算答案每个点(l,r,w)(l,r,w)(l,r,w)表示以l∼rl\sim rl∼r为结尾最长的不降升子序…

设计模式之策略模式在地铁票价系统中的应用

引言设计模式是面向对象编程的一个非常精彩的部分。使用设计模式是为了可重用代码、让代码更容易被他人理解、保证代码可靠性&#xff0c;它能帮助我们将应用组织成容易了解&#xff0c;容易维护&#xff0c;具有弹性的架构。本文通过一个简单的案例来讲述策略模式在地铁票价系…

jzoj3339-[NOI2013模拟]wyl8899和法法塔的游戏【博弈论,暴力】

正题 题目大意 有nnn堆石子&#xff0c;每次选择一个区间博弈&#xff0c;先手必须先取最右边的石子堆。 每次询问(r,a,b)(r,a,b)(r,a,b)表示在a∼ba\sim ba∼b中选择一个数lll。要求使用l∼rl\sim rl∼r这个区间的石子进行博弈&#xff0c;然后若先手必胜输出最右边的石子需…

Sentinel(十九)之主流框架的适配

转载自 主流框架的适配 注&#xff1a;适配模块仅提供相应适配功能&#xff0c;若希望接入 Sentinel 控制台&#xff0c;请务必参考 Sentinel 控制台文档。 云原生微服务体系 Spring Cloud Spring Cloud Alibaba 致力于提供微服务开发的一站式解决方案。Sentinel 与 Spring …

利用OCR文字识别+百度算法搜索,玩转冲顶大会、百万英雄、芝士超人等答题赢奖金游戏

【先上一张效果图】&#xff1a;一、原理&#xff1a;其实原理很简单&#xff1a;1.手机投屏到电脑&#xff1b;2.截取投屏画面的题目部分&#xff0c;进行识别&#xff0c;得到题目和三个答案&#xff1b;3.将答案按照一定的算法&#xff0c;进行搜索&#xff0c;得出推荐答案…

Sentinel(二十)之Envoy RLS Token Server

转载自 Envoy RLS Token Server Sentinel 提供了一个 Envoy Global Rate Limiting gRPC Service 的实现 sentinel-cluster-server-envoy-rls&#xff0c;借助集群限流 token server 来为 Envoy 服务网格提供集群流量控制的能力。 Note: You can refer to here for the Englis…

欢乐纪中某A组赛【2019.7.9】

前言 我好菜我好菜我好菜我好菜我好菜 我好菜我好菜我好菜我好菜我好菜 我好菜我好菜我好菜我好菜我好菜 我好菜我好菜我好菜我好菜我好菜 我好菜我好菜我好菜我好菜我好菜 我好菜我好菜我好菜我好菜我好菜 心态大崩 ZYCdalaoZYCdalaoZYCdalao去AKBAK\ BAK B组了所以应该是我垫…

g4e基础篇#5 创建分支和保存代码

使用版本控制系统最常见的工作流程就是修改代码&#xff0c;保存代码&#xff0c;共享代码。Git提供了一个简单的3步工作流&#xff0c;让你方便的完成这些操作。1. 新建工作分支2. 提交更改3. 推送分支到中心存储库与团队成员共享Git 工作流按照以上3步操作&#xff0c;我们就…

P3952-时间复杂度【模拟】

正题 题目链接:https://www.luogu.org/problemnew/show/P3952 题目大意 比较复杂就直接给截图了 解题思路 开一个栈来维护序列&#xff0c;因为它保证合法的程序中一个变量不会相互嵌套所以就拿变量的字母当做每个循环的下标即可。然后对于输入的x,yx,yx,y有五种情况 xN,yN…

Sentinel(二十一)之Sentinel Dashboard控制台日志路径设置

一、sentinel-dashboard配置文件 配置文件内容&#xff1a;Sentinel/sentinel-dashboard/src/main/resources/application.properties #spring settings spring.http.encoding.forcetrue spring.http.encoding.charsetUTF-8 spring.http.encoding.enabledtrue#cookie name se…

一步步部署基于Windows系统的Jenkins持续集成环境

如题&#xff1a;本文将介绍如何在Windows环境下运用Jenkins部署持续集成环境。之所以写本文&#xff0c;是因为在最近工作当中&#xff0c;学习使用Jenkins时&#xff0c;确实遇到了一些问题&#xff0c;而大多数教程文档都是基于Mac或是Linux平台。为此很是头疼&#xff0c;经…

Sentinel(二十二)之使用Nacos存储规则

转载自 Spring Cloud Alibaba基础教程&#xff1a;Sentinel使用Nacos存储规则 通过上一篇《使用Sentinel实现接口限流》的介绍&#xff0c;相信大家对Sentinel已经有了初步的认识。在Spring Cloud Alibaba的整合封装之下&#xff0c;接口限流这件事情可以非常轻易的整合到我们…