“美登杯”上海市高校大学生程序设计邀请赛 (华东理工大学) E 小花梨的数组 线段树
题意

分析
预处理出每个数的最小素因子,首先可以知道\(minprime(x*minprime(x))=minprime(x)\),我们用线段树维护区间最大值\(mx[p]\),注意这里的最大值并不是实际的最大值,同时维护区间\(a[i]\)乘\(minprime(a[i])\)的次数的最小值\(mnt[p]\)
对于操作1,直接区间更新\(mnt[p]\)加1。
对于操作2,有两种情况:
当\(mnt[p]=0\)时,表示当前区间内至少有一个数乘最小素因子的次数为0,一个数除以它的最小素因子后它的最小素因子可能会变化,当一个数为1时,无论怎么操作它都不会再变了,而一个数除它的最小素因子最多\(log\)次就会变成1,所以此时我们直接暴力更新\(mx[p]=mx[p]/minprime(mx[p])\);
当\(mnt[p]\not= 0时\),直接区间更新\(mnt[p]\)减1。
对于操作3,单点查询\(mx[p]\)和\(mnt[p]\),答案为\(mx[p]\times minprime(mx[p])^{mnt[p]}\),用快速幂算一下就行了。
为什么维护区间最大值\(mx[p]\)呢,因为当\(mx[p]=1\)时可以直接剪枝。
时间复杂度\(O(n*log(max(a[i]))*log(n))\)
Code
#include<bits/stdc++.h>
#define fi first
#define se second
#define pb push_back
#define lson l,mid,p<<1
#define rson mid+1,r,p<<1|1
#define ll long long
using namespace std;
const int inf=1e9;
const int mod=1e9+7;
const int maxn=1e5+10;
typedef pair<int,int> pii;
int n,m;
int a[maxn];
int mp[10*maxn];
int mx[maxn<<2],mnt[maxn<<2],tag[maxn<<2];
void pp(int p){
mx[p]=max(mx[p<<1],mx[p<<1|1]);
mnt[p]=min(mnt[p<<1],mnt[p<<1|1]);
}
void pd(int p,int k){
mnt[p]+=k;
tag[p]+=k;
}
void bd(int l,int r,int p){
if(l==r){
mx[p]=a[l];
return;
}int mid=l+r>>1;
bd(lson);bd(rson);pp(p);
}
void up(int dl,int dr,int l,int r,int p,int k){
if(mx[p]==1) return;
if(l>=dl&&r<=dr){
if(mnt[p]==0&&k==-1){
if(l==r){
mx[p]/=mp[mx[p]];
return;
}
}else{
mnt[p]+=k;
tag[p]+=k;
return;
}
}int mid=l+r>>1;
pd(p<<1,tag[p]);pd(p<<1|1,tag[p]);tag[p]=0;
if(dl<=mid) up(dl,dr,lson,k);
if(dr>mid) up(dl,dr,rson,k);
pp(p);
}
pii qy(int x,int l,int r,int p){
if(l==r){
return pii(mx[p],mnt[p]);
}int mid=l+r>>1;
pd(p<<1,tag[p]);pd(p<<1|1,tag[p]);tag[p]=0;
if(x<=mid) return qy(x,lson);
else return qy(x,rson);
}
int getmp(int x){
for(int i=2;i*i<=x;i++){
if(x%i==0) return i;
}
return x;
}
ll ksm(ll a,ll b){
ll ret=1;
while(b){
if(b&1) ret=ret*a%mod;
b>>=1;
a=a*a%mod;
}
return ret;
}
int main(){
//ios::sync_with_stdio(false);
//freopen("in","r",stdin);
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++){
scanf("%d",&a[i]);
}mp[1]=1;
for(int i=2;i<=1000000;i++){
mp[i]=getmp(i);
}bd(1,n,1);
while(m--){
int op,l,r,x;
scanf("%d",&op);
if(op==1){
scanf("%d%d",&l,&r);
up(l,r,1,n,1,1);
}else if(op==2){
scanf("%d%d",&l,&r);
up(l,r,1,n,1,-1);
}else{
scanf("%d",&x);
pii ret=qy(x,1,n,1);
ll ans=1ll*ret.fi*ksm(mp[ret.fi],ret.se)%mod;
printf("%lld\n",ans);
}
}
return 0;
}
“美登杯”上海市高校大学生程序设计邀请赛 (华东理工大学) E 小花梨的数组 线段树的更多相关文章
- “美登杯”上海市高校大学生程序设计邀请赛 **D. 小花梨的取石子游戏**
"美登杯"上海市高校大学生程序设计邀请赛 (华东理工大学) D. 小花梨的取石子游戏 Description 小花梨有
- 美登杯”上海市高校大学生程序设计邀请赛 Problem E 、 小 花梨 的数组 (线段树)
Problem E E . 小 花梨 的数组 时间限制:1000ms 空间限制:512MB Description 小花梨得到了一个长度为
- “美登杯”上海市高校大学生程序设计 C. 小花梨判连通 (并查集+map)
Problem C C . 小 花梨 判连通 时间限制:2000ms 空间限制:512MB Description 小花梨给出
- “美登杯”上海市高校大学生程序设计赛B. 小花梨的三角形(模拟,实现)
题目链接:https://acm.ecnu.edu.cn/contest/173/problem/B/#report9 Problem B B . 小 花梨 的 三角形 时间限制:1000ms 空间限 ...
- “美登杯”上海市高校大学生程序设计 E. 小花梨的数组 (线段树)
https://acm.ecnu.edu.cn/contest/173/problem/E/ 分析: 考虑这样一种情况,如果对一个点连续地做几次乘操作,那么之后紧跟着的除操作只需要将乘操作的次数减少即 ...
- 2014嘉杰信息杯ACM/ICPC湖南程序设计邀请赛暨第六届湘潭市程序设计竞赛
比赛链接: http://202.197.224.59/OnlineJudge2/index.php/Contest/problems/contest_id/36 题目来源: 2014嘉杰信息杯ACM ...
- FZU - 2039 Pets (二分图匹配 2011年全国大学生程序设计邀请赛(福州))
Description Are you interested in pets? There is a very famous pets shop in the center of the ACM ci ...
- 2018中国大学生程序设计竞赛 - 网络选拔赛 1010 YJJ's Salesman 【离散化+树状数组维护区间最大值】
题目传送门:http://acm.hdu.edu.cn/showproblem.php?pid=6447 YJJ's Salesman Time Limit: 4000/2000 MS (Java/O ...
- XTU OJ 1209 Alice and Bob 2014(嘉杰信息杯ACM/ICPC湖南程序设计邀请赛暨第六届湘潭市程序设计竞赛)
Problem Description The famous "Alice and Bob" are playing a game again. So now comes the ...
随机推荐
- qt 静态编译配置项
configure -confirm-license -opensource -platform win32-msvc2013 -debug-and-release -static -prefix & ...
- ASP.NET Core如何限制请求频率
原文:ASP.NET Core如何限制请求频率 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.ne ...
- Java并发编程——线程池
本文的目录大纲: 一.Java中的ThreadPoolExecutor类 二.深入剖析线程池实现原理 三.使用示例 四.如何合理配置线程池的大小 一.Java中的ThreadPoolExecutor类 ...
- 用php连接数据库,并执行数据库操作
1,建立与数据库之间的连接 (能通过php代码执行一个SQL语句得到查询的结果) <?php mysqli_connect(' , 'demo01'); 这里要注意两个问题: ①mysqli 是 ...
- linux 进程优先级 调度 nice pri
转:http://www.linuxidc.com/Linux/2016-05/131244.htm 深入 Linux 的进程优先级 [日期:2016-05-11] 来源:liwei.life 作者 ...
- python常用模块:标准文件及模块练习
1.请写出规范目录 并解释各文件夹的作用 bin 执行文件core 核心业务逻辑conf 配置文件lib 库.公共代码.第三方模块db 数据分析log 日志文件readme 文本文档 2.改造atm+ ...
- C++堆排序算法的实现
堆排序(Heap sort)是指利用堆这种数据结构所设计的一种排序算法.堆积是一个近似完全二叉树的结构,并同时满足堆积的性质:即子结点的键值或索引总是小于(或者大于)它的父节点.堆排序可以用到上一次的 ...
- idea 下gradle创建springboot 项目
InterlijIdea 开发环境下创建基于springBoot的项目. 环境 1.jdk1.5以上 2.interlijidea 15 以上 步骤 1.File –>new –>Proj ...
- LeetCode3.无重复字符的最大子串
给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度. 示例 1: 输入: "abcabcbb"输出: 3 解释: 因为无重复字符的最长子串是 "abc&quo ...
- NOIP2016 Day1 T2 天天爱跑步(树上差分,LCA)
原文链接 原题链接 题目描述 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.<天天爱跑步>是一个养成类游戏,需要玩家每天按时上线,完成打卡任务. 这个游戏 ...