BZOJ3813: 奇数国
欧拉函数+线段树
因为只有60个素数,所以把状态压成long long的形式。用线段树维护区间和和区间和中有多少个质数。然后xjb搞搞就行了,具体参见代码。
//BZOJ 3813
//by Cydiater
//2016.10.10
#include <iostream>
#include <cstdlib>
#include <cstdio>
#include <cmath>
#include <queue>
#include <map>
#include <ctime>
#include <cstring>
#include <string>
#include <algorithm>
#include <iomanip>
using namespace std;
#define ll long long
#define up(i,j,n) for(ll i=j;i<=n;i++)
#define down(i,j,n) for(ll i=j;i>=n;i--)
const ll MAXN=1e6+5;
const ll oo=1LL<<60;
const ll mod=19961993;
const ll LIM=1e6;
const ll N=1e5;
inline ll read(){
char ch=getchar();ll x=0,f=1;
while(ch>'9'||ch<'0'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x*f;
}
ll inv[MAXN],prime[MAXN],cnt=0,T,x,y,k,v;
struct Tree{
ll S,v;
}t[MAXN<<2];
bool vis[MAXN];
namespace solution{
void exgcd(ll a,ll b,ll &x,ll &y){
if(b==0){x=1;y=0;return;}
exgcd(b,a%b,x,y);
ll t=x;x=y;y=t-a/b*y;
}
ll get_inv(ll a,ll b){
ll x,y;
exgcd(a,b,x,y);
while(x<0)x+=b;
return x;
}
ll get_suf(ll S){
ll ans=1;
up(i,0,59)if((1LL<<i)&S)
ans=(ans*(prime[i+1]-1)%mod*inv[i+1]%mod)%mod;
return ans;
}
ll get_two(ll num){
ll S=0;
up(i,1,60)if(num%prime[i]==0)S|=(1LL<<(i-1));
return S;
}
Tree merge(Tree x,Tree y){
x.S|=y.S;
(x.v*=y.v)%=mod;
return x;
}
void pret(){
memset(vis,0,sizeof(vis));
up(i,2,LIM){
if(!vis[i])prime[++cnt]=i;
up(j,1,cnt){
if(prime[j]*i>LIM)break;
vis[i*prime[j]]=1;
if(i%prime[j]==0)break;
}
}
up(i,1,60)inv[i]=get_inv(prime[i],mod);
}
void build(int leftt,int rightt,int root){
if(leftt==rightt){
t[root].S=1<<1;
t[root].v=3;
return;
}
int mid=(leftt+rightt)>>1;
build(leftt,mid,root<<1);
build(mid+1,rightt,root<<1|1);
t[root].S=t[root<<1].S|t[root<<1|1].S;
t[root].v=t[root<<1].v*t[root<<1|1].v%mod;
}
Tree get(int leftt,int rightt,int root){
if(leftt>y||rightt<x) return (Tree){0,1};
if(leftt>=x&&rightt<=y) return t[root];
int mid=(leftt+rightt)>>1;
Tree tmp=merge(get(leftt,mid,root<<1),get(mid+1,rightt,root<<1|1));
return tmp;
}
void updata(int leftt,int rightt,int root){
if(leftt>k||rightt<k) return;
if(leftt==rightt){
t[root].v=v;
t[root].S=get_two(v);
return;
}
int mid=(leftt+rightt)>>1;
updata(leftt,mid,root<<1);
updata(mid+1,rightt,root<<1|1);
t[root]=merge(t[root<<1],t[root<<1|1]);
}
void slove(){
T=read();
while(T--){
ll a=read(),b=read(),c=read();
if(a==0){
x=b;y=c;
Tree tmp=get(1,N,1);
printf("%lld\n",tmp.v*get_suf(tmp.S)%mod);
}else{
k=b;v=c;
updata(1,N,1);
}
}
}
}
int main(){
//freopen("input.in","r",stdin);
using namespace solution;
pret();
build(1,N,1);
slove();
return 0;
}
BZOJ3813: 奇数国的更多相关文章
- [BZOJ3813] 奇数国 - 线段树
3813: 奇数国 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 912 Solved: 508[Submit][Status][Discuss] ...
- [bzoj3813] 奇数国 [线段树+欧拉函数]
题面 传送门 思路 这题目是真的难读......阅读理解题啊...... 但是理解了以后就发现,题目等价于: 给你一个区间,支持单点修改,以及查询一段区间的乘积的欧拉函数值,这个答案对19961993 ...
- 【BZOJ3813】奇数国 线段树+欧拉函数
[BZOJ3813]奇数国 Description 给定一个序列,每次改变一个位置的数,或是询问一段区间的数的乘积的phi值.每个数都可以表示成前60个质数的若干次方的乘积. Sample Input ...
- 【bzoj3813】: 奇数国 数论-线段树-欧拉函数
[bzoj3813]: 奇数国 题意:给定一个序列,每个元素可以分解为最小的60个素数的形式.(x=p1^k1*p2^k2*......p60^k60)(p1=2,p2=3,…,p60=281) 支持 ...
- [BZOJ 3813]奇数国
3813: 奇数国 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 736 Solved: 416[Submit][Status][Discuss] ...
- AC日记——【清华集训2014】奇数国 uoj 38
#38. [清华集训2014]奇数国 思路: 题目中的number与product不想冲: 即为number与product互素: 所以,求phi(product)即可: 除一个数等同于在模的意义下乘 ...
- Bzoj 3813 奇数国 题解 数论+线段树+状压
3813: 奇数国 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 748 Solved: 425[Submit][Status][Discuss] ...
- HYSBZ - 3813 奇数国 欧拉函数+树状数组(线段树)
HYSBZ - 3813奇数国 中文题,巨苟题,巨无敌苟!!首先是关于不相冲数,也就是互质数的处理,欧拉函数是可以求出互质数,但是这里的product非常大,最小都2100000,这是不可能实现的.所 ...
- 【BZOJ3813】【清华集训2014】奇数国 线段树 数学
题目描述 给你一个长度为\(n\)的数列,第\(i\)个数为\(a_i\).每个数的质因子都只有前\(60\)个质数.有\(q\)个询问,每次给你\(l,r\),求\(\varphi(\prod_{i ...
随机推荐
- 项目分享二:APP 小红点中数字的处理
小红点,是 APP 中最常见的一个功能,我们先来看一下面的案例,下图中,待评价的商品有 2 个,点击“评价晒单”按钮进行评价后,那么待评价数量应该变成 1,那么这个功能是如何去实现的呢? 一般来说,实 ...
- Android开发之补间动画、XML方式定义补间动画
四种补间动画: 1.透明: 2.缩放: 3.位移: 4.旋转: //点击按钮 实现iv 透明的效果 动画 public void click1(View v) { //1.0意味着着完全不透明 0.0 ...
- 虚拟机VirtualBox 5.1.0|VBOX
Oracle VM VirtualBox是一款免费.开源的虚拟机软件,现属于Oracle旗下产品.可以安装Windows.Linux.IBM OS/2.Solaris.BSD等操作系统,具有远端桌面协 ...
- win7远程桌面连接不上,解决办法
来源于:http://jingyan.baidu.com/article/39810a23edc48bb637fda672.html 一般情况下,对WIN7的远程连接只需要5步即可完成远程连接的设置: ...
- Query DSL for elasticsearch Query
Query DSL Query DSL (资料来自: http://www.elasticsearch.cn/guide/reference/query-dsl/) http://elasticsea ...
- Shell命令_文件系统常用命令df、du
一.df(文件系统查看命令) [root@localhost ~]# df [选项] [挂载点] 选项: -a 显示所有的文件系统信息,包括特殊文件系统,如 /proc. /sysfs -h 使用习惯 ...
- java-commons-HttpClient超时设置setConnectionTimeout和setSoTimeout
问题 之前使用httpclient请求数据 源码方法: public static String doHttp(HttpMethod result, int timeout, String chars ...
- jar-下载站点
nutch: http://archive.apache.org/dist/nutch/ jarfire: http://cn.jarfire.org/ solr: http://archive.ap ...
- json2form实例
<!DOCTYPE html> <html lang="en" xmlns="http://www.w3.org/1999/xhtml"> ...
- iOS随机生成数字
有时候我们需要在程序中生成随机数,但是在Objective-c中并没有提供相应的函数,好在C中提供了rand().srand().random().arc4random()几个函数.那么怎么使用呢?下 ...