【NOIP2016提高组A组7.16】第三条跑道
题目
数据范围
分析
时限5000ms。
我们注意到\(a_{i}初始值以及x小于等于600且非零\)
也就是说,\(a_{i}\)的质因数一定小于600,而600以内的质因数只有109个。
那么考虑常用于区间修改的线段树。
用线段树来维护某个位置的某个质因数的总乘积,以及某个质因数出现的位置的个数。
时间复杂度\(O(QlogN·109)\)
#include <cmath>
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <queue>
const long long maxlongint=2147483647;
const long long mo=100000007;
const long long N=50005;
using namespace std;
struct ddx
{
long long a[120],v[120],lazy[120],sum[120];
}tree[50005];
long long ss[80000],n,m,ny[1000005],belong[1000005];
long long ans,re[10005];
bool b[1000005];
long long mi(long long x,long long y)
{
long long sum=1;
while(y)
{
if(y&1) sum=x*sum%mo;
x=x*x%mo;
y/=2;
}
return sum;
}
long long put(long long v,long long l,long long r,long long x,long long y,long long z)
{
if(l==r)
{
tree[v].a[y]=z;
tree[v].v[y]=tree[v].v[y]*mi(ss[y],z)%mo;
tree[v].sum[y]=1;
return 0;
}
long long mid=(l+r)/2;
if(x<=mid)
put(v*2,l,mid,x,y,z);
else put(v*2+1,mid+1,r,x,y,z);
for(long long i=1;i<=109;i++)
{
tree[v].a[i]=(tree[v*2].a[i]+tree[v*2+1].a[i])%mo;
tree[v].v[i]=tree[v*2].v[i]*tree[v*2+1].v[i]%mo;
tree[v].sum[i]=tree[v*2].sum[i]+tree[v*2+1].sum[i];
}
}
long long down(long long v,long long mid,long long l,long long r,long long y)
{
if(!tree[v].lazy[y]) return 0;
long long z=tree[v].lazy[y];
tree[v*2].a[y]+=z*(mid-l+1);
tree[v*2+1].a[y]+=z*(r-mid);
tree[v*2].v[y]=tree[v*2].v[y]*mi(ss[y],z*(mid-l+1))%mo;
tree[v*2+1].v[y]=tree[v*2+1].v[y]*mi(ss[y],z*(r-mid))%mo;
tree[v*2].lazy[y]+=z;
tree[v*2+1].lazy[y]+=z;
tree[v*2].sum[y]=(mid-l+1);
tree[v*2+1].sum[y]=(r-mid);
tree[v].lazy[y]=0;
}
long long change(long long v,long long l,long long r,long long x,long long x1,long long y,long long z)
{
if(l==x && r==x1)
{
tree[v].a[y]=(tree[v].a[y]+z*(r-l+1))%mo;
tree[v].v[y]=tree[v].v[y]*mi(ss[y],z*(r-l+1))%mo;
tree[v].sum[y]=(r-l+1);
tree[v].lazy[y]+=z;
return 0;
}
long long mid=(l+r)/2;
for(long long i=1;i<=109;i++) down(v,mid,l,r,i);
if(x1<=mid)
change(v*2,l,mid,x,x1,y,z);
else
if(x>mid)
change(v*2+1,mid+1,r,x,x1,y,z);
else
change(v*2,l,mid,x,mid,y,z),change(v*2+1,mid+1,r,mid+1,x1,y,z);
for(long long i=1;i<=109;i++)
{
tree[v].a[i]=(tree[v*2].a[i]+tree[v*2+1].a[i])%mo;
tree[v].v[i]=tree[v*2].v[i]*tree[v*2+1].v[i]%mo;
tree[v].sum[i]=tree[v*2].sum[i]+tree[v*2+1].sum[i];
}
}
long long find(long long v,long long l,long long r,long long x,long long x1)
{
if(l==x && r==x1)
{
for(long long i=1;i<=109;i++)
{
if(tree[v].sum[i])
ans=ans*tree[v].v[i]%mo*mi(ny[ss[i]],tree[v].sum[i])%mo*mi(ss[i]-1,tree[v].sum[i])%mo;
}
return 0;
}
long long mid=(l+r)/2;
for(long long i=1;i<=109;i++) down(v,mid,l,r,i);
if(x1<=mid)
find(v*2,l,mid,x,x1);
else
if(x>mid)
find(v*2+1,mid+1,r,x,x1);
else
find(v*2,l,mid,x,mid),find(v*2+1,mid+1,r,mid+1,x1);
for(long long i=1;i<=109;i++)
{
tree[v].a[i]=(tree[v*2].a[i]+tree[v*2+1].a[i])%mo;
tree[v].v[i]=tree[v*2].v[i]*tree[v*2+1].v[i]%mo;
tree[v].sum[i]=tree[v*2].sum[i]+tree[v*2+1].sum[i];
}
}
int main()
{
memset(b,true,sizeof(b));
b[0]=0;
b[1]=0;
for(long long i=2;i<=10000;i++)
{
if(b[i])
{
ss[++ss[0]]=i;
ny[i]=mi(i,mo-2);
belong[i]=ss[0];
}
for(long long j=1;j<=ss[0];j++)
{
if(i*ss[j]<=10000)
b[i*ss[j]]=false;
else break;
if(!(i%ss[j])) break;
}
}
scanf("%lld",&n);
for(long long i=1;i<=50001;i++)
for(long long j=1;j<=110;j++)
tree[i].v[j]=1;
for(long long j=1;j<=n;j++)
{
scanf("%lld",&re[j]);
long long p=re[j];
if(b[p])
{
put(1,1,n,j,belong[p],1);
}
else
{
for(long long k=1;ss[k]<=sqrt(re[j]) && p>1;k++)
{
long long w=0;
while(!(p%ss[k]))
{
p/=ss[k];
w++;
}
if(w)
{
put(1,1,n,j,k,w);
}
}
if(p>1)
{
put(1,1,n,j,belong[p],1);
}
}
}
long long q;
scanf("%lld",&q);
for(long long i=1;i<=q;i++)
{
long long t,x,y,z;
scanf("%lld%lld%lld",&t,&x,&y);
if(t)
{
ans=1;
find(1,1,n,x,y);
printf("%lld\n",ans);
}
else
{
scanf("%lld",&z);
long long p=z;
if(b[p])
{
change(1,1,n,x,y,belong[p],1);
}
else
{
for(long long k=1;ss[k]<=sqrt(z) && p>1;k++)
{
long long w=0;
while(!(p%ss[k]))
{
p/=ss[k];
w++;
}
if(w)
{
change(1,1,n,x,y,k,w);
}
}
if(p>1)
{
change(1,1,n,x,y,belong[p],1);
}
}
}
}
}
【NOIP2016提高组A组7.16】第三条跑道的更多相关文章
- JZOJ 【NOIP2016提高A组集训第16场11.15】兔子
JZOJ [NOIP2016提高A组集训第16场11.15]兔子 题目 Description 在一片草原上有N个兔子窝,每个窝里住着一只兔子,有M条路径连接这些窝.更特殊地是,至多只有一个兔子窝有3 ...
- JZOJ 【NOIP2016提高A组集训第16场11.15】SJR的直线
JZOJ [NOIP2016提高A组集训第16场11.15]SJR的直线 题目 Description Input Output Sample Input 6 0 1 0 -5 3 0 -5 -2 2 ...
- NOIP2016提高组解题报告
NOIP2016提高组解题报告 更正:NOIP day1 T2天天爱跑步 解题思路见代码. NOIP2016代码整合
- 5820. 【NOIP提高A组模拟2018.8.16】 非法输入(模拟,字符串)
5820. [NOIP提高A组模拟2018.8.16] 非法输入 (File IO): input:aplusb.in output:aplusb.out Time Limits: 1000 ms ...
- JZOJ 4732. 【NOIP2016提高A组模拟8.23】函数
4732. [NOIP2016提高A组模拟8.23]函数 (Standard IO) Time Limits: 1500 ms Memory Limits: 262144 KB Detailed ...
- 【题解】NOIP2016提高组 复赛
[题解]NOIP2016提高组 复赛 传送门: 玩具谜题 \(\text{[P1563]}\) 天天爱跑步 \(\text{[P1600]}\) 换教室 \(\text{[P1850]}\) 组合数问 ...
- 【题解】NOIP2016 提高组 简要题解
[题解]NOIP2016 提高组 简要题解 玩具迷题(送分) 用异或实现 //@winlere #include<iostream> #include<cstdio> #inc ...
- iOS之UITableView组头组尾视图/标题悬停
最近笔者在公司的iOS开发中,有一个iOS开发同事跑来问了两个问题:1.给UITableView设置了组头和组尾视图,但是一直显示不出来?2.UITableView的section的header和fo ...
- iOS自定义组与组之间的距离以及视图
iOS自定义组与组之间的距离以及视图 //头视图高度 - (CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(N ...
随机推荐
- Python学习之==>面向对象编程(一)
一.面向对象与面向过程 面向对象与面向过程是两种不同的编程范式,范式指的是按照什么方式去编程.去实现一个功能.不同的编程范式本质上代表对各种不同类型的任务采取不同的解决问题的思路. 1.面向过程编程 ...
- 封装一个windows转发端口的脚本
使用方法: 1.打开文本编辑工具如(Notepad++) 2.新建文件 3.注意:修改文本的编码字符集为:gb2312 4.将下面代码 复制入文件 5.保存文件名为:transmit.bat 6.双击 ...
- 【MM系列】 MM60增强
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[MM系列] MM60增强 前言部分 大家可 ...
- C#得到10000以内素数
偶数除了二都不是素数 一个数 n 如果是合数,那么它的所有的因子不超过sqrt(n)--n的开方 int i, j, n = 10000; for (i = 3; i <= n; i += 2) ...
- python-应用OpenCV和Python进行SIFT算法的实现
如下图为进行测试的q和h,分别验证基于BFmatcher.FlannBasedMatcher等的SIFT算法 代码如下: import numpy as np import cv2 from matp ...
- Spring对Jdbc的封装——JdbcTemplate的使用
链接:https://pan.baidu.com/s/15luDElW4oeEaP0nvEQ_40w 提取码:i2r1 JdbcTemplate是Spring对JDBC的封装,目的是使JDBC更加易于 ...
- QML - 实现Gstreamer投屏 投屏画面遮挡
1. 背景介绍 中控端运行的操作系统是Android,中控软件主要功能有导航.收音机.媒体(音乐).蓝牙(连接).手机互联.行车辅助和系统设置等. 仪表端运行的操作系统是Linux,仪表软件主 ...
- 如何在ubuntu上安装 搜狗输入法(已经成功)
转自:https://blog.csdn.net/qq_37589838/article/details/81208409 本文链接:https://blog.csdn.net/qq_37589838 ...
- 2019 Multi-University Training Contest 2 - 1011 - Keen On Everything But Triangle - 线段树
http://acm.hdu.edu.cn/showproblem.php?pid=6601 首先要贪心地想,题目要最长的边长,那么要怎么构造呢?在一段连续的区间里面,一定是拿出最长的三根出来比,这样 ...
- P2510 [HAOI2008]下落的圆盘
传送门 首先考虑两个圆覆盖的情况,我们可以求出圆心与交点连线 $A$ 的极角 具体就是求出两圆心连线 $B$ 极角加上余弦定理加反余弦求出 $A,B$ 之间夹角 ,然后覆盖了多少就可以得出 但是多个圆 ...