清橙A1339. JZPLCM(顾昱洲)
http://www.tsinsen.com/ViewGProblem.page?gpid=A1339
题解:https://blog.csdn.net/LOI_DQS/article/details/51251737
对着题解A掉了。。。然而并不知道为什么要这么转化问题。。。
复杂度nlog^2n级别吧
#include<cstdio>
#include<algorithm>
#include<map>
#include<cmath>
#define fi first
#define se second
#define md 1000000007
using namespace std;
typedef long long LL;
typedef pair<int,int> P;
int a[],d[],nxt[],pos[],len;
bool vis[];
int prime[];
bool fir[];
void dprime(int x,map<int,int> &ma)
{
ma.clear();
if(x<=) return;
int i,end=floor(sqrt(x+0.5));
for(i=;prime[i]<=end;i++)
while(x!=prime[i])
{
if(x%prime[i]==)
{
ma[prime[i]]++;
x/=prime[i];
}
else
break;
}
ma[x]++;
}
int n,qq;
namespace S
{
#define mid (l+((r-l)>>1))
#define lc (num<<1)
#define rc (num<<1|1)
int dat[];
void build(int l,int r,int num)
{
if(l==r){dat[num]=fir[l]?d[l]:;return;}
build(l,mid,lc);build(mid+,r,rc);
dat[num]=LL(dat[lc])*dat[rc]%md;
}
int L,R,x;
void upd(int l,int r,int num)
{
if(l==r) {dat[num]=x;return;}
if(L<=mid) upd(l,mid,lc);
else upd(mid+,r,rc);
dat[num]=LL(dat[lc])*dat[rc]%md;
}
int que(int l,int r,int num)
{
if(L<=l&&r<=R) return dat[num];
int ans=;
if(L<=mid) ans=LL(ans)*que(l,mid,lc)%md;
if(mid<R) ans=LL(ans)*que(mid+,r,rc)%md;
return ans;
}
#undef mid
#undef lc
#undef rc
}
int poww(int a,int b)
{
LL ans=,base=a;
for(;b;base=base*base%md,b>>=)
if(b&)
ans=ans*base%md;
return ans;
}
struct Q
{
int l,r,num,ans;
}q[];
bool operator<(const Q &a,const Q &b) {return a.l<b.l||(a.l==b.l&&a.r<b.r);}
bool cmp(const Q &a,const Q &b) {return a.num<b.num;}
int main()
{
int i,j,t;map<int,int> tans;
map<int,int>::iterator it;
for(i=;i<=;i++)
{
if(!vis[i]) prime[++prime[]]=i;
for(j=;j<=prime[]&&i*prime[j]<=;j++)
{
vis[i*prime[j]]=;
if(i%prime[j]==) break;
}
}
scanf("%d%d",&n,&qq);
for(i=;i<=n;i++)
{
scanf("%d",&t);dprime(t,tans);
for(it=tans.begin();it!=tans.end();it++)
for(j=;j<=it->second;j++)
++len,a[len]=poww(it->first,j),d[len]=it->first;
pos[i]=len;
}
tans.clear();
for(i=;i<=len;i++)
{
if(!tans[a[i]]) fir[i]=;
else nxt[tans[a[i]]]=i;
tans[a[i]]=i;
}
S::build(,len,);
for(i=;i<=qq;i++) scanf("%d%d",&q[i].l,&q[i].r),q[i].num=i,q[i].l=pos[q[i].l-]+,q[i].r=pos[q[i].r];
sort(q+,q+qq+);
for(i=,j=;i<=qq;i++)
{
for(;j<q[i].l;)
{
if(nxt[j])
{
S::L=nxt[j];S::x=d[nxt[j]];S::upd(,len,);
}
++j;
}
S::L=q[i].l;S::R=q[i].r;
q[i].ans=S::que(,len,);
}
sort(q+,q+qq+,cmp);
for(i=;i<=qq;i++) printf("%d\n",q[i].ans);
return ;
}
清橙A1339. JZPLCM(顾昱洲)的更多相关文章
- 【刷题】清橙 A1339 JZPLCM(顾昱洲)
试题来源 2012中国国家集训队命题答辩 问题描述 给定一长度为n的正整数序列a,有q次询问,每次询问一段区间内所有数的lcm(即最小公倍数).由于答案可能很大,输出答案模1000000007. 输入 ...
- 清橙A1212:剪枝
题面 清橙 Sol 一种新的树上\(DP\)姿势 从左往右按链\(DP\) 做法: 维护两个栈\(S1\),\(S2\) \(S1\)存当前的链 \(S2\)存分叉点以下要改的链 \(Dfs\),弄一 ...
- 清橙A1202&Bzoj2201:彩色圆环
因为Bzoj是权限题,所以可以去清橙做一下 Sol 突然考了一道这样的题,考场上强行\(yy\)出来了 win下评测Long double爆零TAT 首先肯定是破环为链变成序列问题辣 那么就要求第一个 ...
- [清橙A1210]光棱坦克
[清橙A1210]光棱坦克 题目大意: 平面上放置了\(n(n\le7000)\)个反射装置,光纤将从某个装置出发,在经过一处装置时发生反射,若经过的装置坐标依次为\((x_1,y_1),(x_2,y ...
- 清橙A1206.小Z的袜子 && CF 86D(莫队两题)
清橙A1206.小Z的袜子 && CF 86D(莫队两题) 在网上看了一些别人写的关于莫队算法的介绍,我认为,莫队与其说是一种算法,不如说是一种思想,他通过先分块再排序来优化离线查询问 ...
- 洛谷 P1903 BZOJ 2120 清橙 A1274【模板】分块/带修改莫队(数颜色)(周奕超)
试题来源 2011中国国家集训队命题答辩 题目描述 墨墨购买了一套N支彩色画笔(其中有些颜色可能相同),摆成一排,你需要回答墨墨的提问.墨墨会像你发布如下指令: 1. Q L R代表询问你从第L支画笔 ...
- 清橙 A1206 小Z的袜子(莫队算法)
A1206. 小Z的袜子 时间限制:1.0s 内存限制:512.0MB 总提交次数:1357 AC次数:406 平均分:46.75 将本题分享到: 查看未格式化的试题 ...
- 清橙A1363. 水位 - 清华大学2012年信息学优秀高中学子夏令营
问题描述 有一个正方形的地区,该地区特点鲜明:如果把它等分为N×N个小正方形格子的话,在每个格子内的任意地点的地表高度是相同的,并且是一个0到M之间的整数.正方形地区的外部被无限高的边界包围. 该地区 ...
- 清橙 A1120 拦截导弹 -- 动态规划(最长上升子序列)
题目地址:http://oj.tsinsen.com/A1120 问题描述 某国为了防御敌国的导弹袭击,发展出一种导弹拦截系统.但是这种导弹拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但 ...
随机推荐
- 项目Beta冲刺(团队7/7)
项目Beta冲刺(团队7/7) 团队名称: 云打印 作业要求: 项目Beta冲刺(团队) 作业目标: 完成项目Beta版本 团队队员 队员学号 队员姓名 个人博客地址 备注 221600412 陈宇 ...
- (转)OutOfMemory时抓取heap 快照
转自:https://testerhome.com/topics/579 首先说一下,在程序没有崩溃的时候如何抓取heap快照.这个大家应该都知道,在ddms中自带此功能. 见上图首先我们选中一个 ...
- C# does not contain a constructor that takes no parameter
C# 中子类要重用父类的构造函数时, 一般会在子类构造函数后面调用 : base(paratype, para). 如果父类有一个參数个数为1的构造函数, 没有 0 參构造函数. 子类想要重用这个构造 ...
- String池与iterator对集合的迭代
一.静态导入 1. 导入类的静态属性 import static java.lang.System.out; out.println("haha"); 2. ...
- MyCAT简单入门配置
MyCAT简单入门配置 安装jdk 建议1.7以上 安装mysql 安装MyCAT Mycat 源码:https://github.com/MyCATApache/Mycat-Server Mycat ...
- Xamarin.Android 记事本(一)
导读 1.视图及数据库的创建 2.listview数据绑定 3.listview的点击事件 正文 如何创建一个listview,大家可以看这里,基本流程操作是一模一样的,我就不多说了,然后就是新建一个 ...
- Ruby map、each、select、inject、collect 、detect reference
参考 https://ruby-china.org/topics/26718 map:(collect是map的别名函数) 对数组中每个元素进行表达式操作,原始数组不会被改变,返回执行表达式结果的新数 ...
- 蓝牙BlueTooth技术学习理解
1.BLUETOOTH基本了解 BLUETOOTH出自丹麦 Bluetooth SIG 蓝牙技术联盟,非盈利组织.主要任务是发布蓝牙规格.管理资格认证程序.保护蓝牙商标及宣传蓝牙无线技术. 重要网站 ...
- django-sso单点登陆的实现
环境准备 环境规格: python3.5 django2.0 django-simple-sso-0.14 环境安装: pip install django-simple-sso-0.14 环境说明: ...
- ASP.NET Session and Forms Authentication and Session Fixation
https://peterwong.net/blog/asp-net-session-and-forms-authentication/ The title can be misleading, be ...