【线段树/数学/扩展欧几里得】 Bzoj 3913:奇数国
Description
Input
Output
看到这题,我们先不去管别的。。先把题意看懂!(说多了都是泪啊QAQ)
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm> #define maxn 100001 #define mod 19961993 typedef long long ll; using namespace std; int prime[],ff[]; ll inv[],x,y; bool is_prime[]; struct tr{
int l,r;
ll ans,mark;
}tree[maxn*]; void exgcd(int n,int m)
{
if(m==){x=,y=;return;}
exgcd(m,n%m);
ll t=x;
x=y,y=t-n/m*y;
} void pre()
{
inv[]=;
int b=;
for(int i=;i<=;i++)
{
if(!is_prime[i])prime[++b]=i,exgcd(i,mod),inv[i]=(x%mod+mod)%mod,ff[i]=b;
int j=,t=*i;
while(j<=b&&t<=)
{
is_prime[t]=;
if(i%prime[j]==){break;}
t=prime[++j]*i;
}
}
return;
} int read()
{
int x=;char ch=getchar();
while(ch<''||ch>'')ch=getchar();
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x;
} void build(int l,int r,int num)
{
tree[num].mark=<<;
if(l==r){tree[num].l=tree[num].r=l;tree[num].ans=;return;}
int mid=(l+r)>>;build(l,mid,num<<);build(mid+,r,(num<<)+);
tree[num].l=l,tree[num].r=r,tree[num].ans=tree[num<<].ans*tree[(num<<)+].ans%mod;
} ll pow(int k)
{
ll x=,ans=;
while(k!=)
{
if(k&)ans=ans*x;
x=x*x;
k>>=;
}
return ans;
} void fen(int shu,int wei)
{
tree[wei].mark=;
for(int i=;i<=sqrt(shu);i++)if(shu%i==&&!is_prime[i]){
while(shu%i==)shu/=i;
tree[wei].mark+=pow(ff[i]);
}
if(shu!=)tree[wei].mark+=pow(ff[shu]);
} void update(int wei,int des,int change)
{
if(tree[wei].l==tree[wei].r){
tree[wei].ans=change;
fen(change,wei);
return;
}
int mid=(tree[wei].l+tree[wei].r)>>;
if(mid>=des)update(wei<<,des,change);
else update((wei<<)+,des,change);
tree[wei].ans=tree[(wei<<)].ans*tree[(wei<<)+].ans%mod;
tree[wei].mark=tree[(wei<<)].mark | tree[(wei<<)+].mark;
} ll ans; ll find(int l,int r,int num)
{
if(tree[num].l==l&&tree[num].r==r){ans=ans*tree[num].ans%mod;return tree[num].mark;}
int mid=(tree[num].l+tree[num].r)>>;
if(mid>=r)return find(l,r,num<<);
else if(mid<l)return find(l,r,(num<<)+);
else return find(l,mid,num<<) | find(mid+,r,(num<<)+);
} ll solve(int l,int r)
{
ll state=find(l,r,);
for(int i=;i<=;i++)
if(state>>i & )ans=(ans*(prime[i]-)%mod*inv[prime[i]]%mod);
return ans;
} int main()
{
int n;
pre();
scanf("%d",&n);
build(,,);
for(int i=;i<=n;i++)
{
bool doing=read();
int x=read(),y=read();
if(doing)update(,x,y);
else ans=,printf("%lld\n",solve(x,y));
}
return ;
}
一定要看清题意!
【线段树/数学/扩展欧几里得】 Bzoj 3913:奇数国的更多相关文章
- 【数学/扩展欧几里得/线性求逆元】[Sdoi2008]沙拉公主的困惑
Description 大富翁国因为通货膨胀,以及假钞泛滥,政府决定推出一项新的政策:现有钞票编号范围为1到N的阶乘,但是,政府只发行编号与M!互质的钞票.房地产第一大户沙拉公主决定预测一下大富翁国现 ...
- 【数学/扩展欧几里得/Lucas定理】BZOJ 1951 :[Sdoi 2010]古代猪文
Description “在那山的那边海的那边有一群小肥猪.他们活泼又聪明,他们调皮又灵敏.他们自由自在生活在那绿色的大草坪,他们善良勇敢相互都关心……” ——选自猪王国民歌 很久很久以前,在山的那边 ...
- 洛谷P3951 小凯的疑惑 - 数学 /扩展欧几里得
传送门 题意:求出a和b不能通过线性组合(即n*a+m*b)得到的最大值: 思路:摘自洛谷: 不妨设 a<b 假设答案为 x 若 x≡m*a ( mod b )(1≤m≤b−1) (mod3)什 ...
- 【数学】【NOIp2012】同余方程 题解 以及 关于扩展欧几里得与同余方程
什么是GCD? GCD是最大公约数的简称(当然理解为我们伟大的党也未尝不可).在开头,我们先下几个定义: ①a|b表示a能整除b(a是b的约数) ②a mod b表示a-[a/b]b([a/b]在Pa ...
- interesting Integers(数学暴力||数论扩展欧几里得)
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAwwAAAHwCAIAAACE0n9nAAAgAElEQVR4nOydfUBT1f/Hbw9202m0r8
- UVa 11768 格点判定(扩展欧几里得求线段整点)
https://vjudge.net/problem/UVA-11768 题意: 给定两个点A(x1,y1)和B(x2,y2),均为0.1的整数倍.统计选段AB穿过多少个整点. 思路: 做了这道题之后 ...
- C. Ray Tracing——披着搜索外衣的扩展欧几里得
[题目大意] 给你一个n*m的矩形,光线从(0,0)出发,沿右上方向以每秒根号2米的速度运动,碰到矩形边界就会反弹(符合物理规律的反弹),询问k个点,这些点都在矩形内部且不在矩形边界上,求光经过这些点 ...
- [P1082][NOIP2012] 同余方程 (扩展欧几里得/乘法逆元)
最近想学数论 刚好今天(初赛上午)智推了一个数论题 我屁颠屁颠地去学了乘法逆元 然后水掉了P3811 和 P2613 (zcy吊打集训队!)(逃 然后才开始做这题. 乘法逆元 乘法逆元的思路大致就是a ...
- code1213 解的个数 扩展欧几里得
很不错的题,加深了我对exgcd的理解 (以前我认为做题就是搜索.dp...原来数学也很重要) 理解了几个小时,终于明白了.但我什么都不打算写. 看代码吧: #include<iostream& ...
随机推荐
- ActiveMQ(5.10.0) - 删除闲置的队列或主题
方法一 通过 ActiveMQ Web 控制台删除. 方法二 通过 Java 代码删除. ActiveMQConnection.destroyDestination(ActiveMQDestinati ...
- 在 Tomcat 中设置 JDBCRealm
除了默认配置的 DataSourceRealm,Tomcat 还支持 JDBCRealm,它通过 JDBC 来访问记录在关系数据库里的认证信息. JDBCRealm 的配置步骤如下: 在 $TOMCA ...
- Asp.net MVC 4 Html帮助类
Html帮助类 used to render (modify and output) HTML form elements 用来渲染HTML表单元素(修改和输出) Html.ActionLink 输出 ...
- HDOJ2030汉字统计
汉字统计 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- C# winform 选择项 省市连动
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...
- 终端命令收集(关于 mac与ubuntu)
本人曾使用ubuntu 是踩过有一些坑,以及在处理问题时学到的知识,总结一下,便于以后记忆. 1 基本命令 (1)列出文件 ls 参数 目录名 参数 -w 显示中文,-l 详细信息, -a 包括隐藏文 ...
- [Accessibility] Missing contentDescription attribute on image [可取行]失踪contentDescription属性图像
问题描述: [Accessibility] Missing contentDescription attribute on image [可取行]失踪contentDescription属性图像 原因 ...
- Linux rar
http://www.vpsyou.com/2010/06/15/to-extract-rar-centos.html wget http://www.rarsoft.com/rar/rarlinux ...
- 一些dos命令
MS DOS 命令大全 一.基础命令 1 dir 无参数:查看当前所在目录的文件和文件夹. /s:查看当前目录已经其所有子目录的文件和文件夹. /a:查看包括隐含文件的所有文件. /ah:只显示出隐含 ...
- C++中delete和delete[]的区别
C++告诉我们在回收用 new 分配的单个对象的内存空间的时候用 delete,回收用 new[] 分配的一组对象的内存空间的时候用 delete[]. 关于 new[] 和 delete[],其中又 ...