Bzoj 3813 奇数国 题解 数论+线段树+状压
3813: 奇数国
Time Limit: 10 Sec Memory Limit: 256 MB
Submit: 748 Solved: 425
[Submit][Status][Discuss]
Description
Input
Output
Sample Input
013
115
013
117
013
023
Sample Output
24
36
6
explanation
初始化每个国家存款都为3;
1到3的product为27,[1,27]与27不相冲的有18个数;
1的存款变为5;
1到3的product为45,[1,45]与45不相冲的有24个数;
1的存款变为7;
1到3的product为63,[1,63]与63不相冲的有36个数;
2到3的product为9,[1,9]与9不相冲的有6个数。
HINT
x≤100000,当ai=0时0≤ci−bi≤100000
Source
#include <iostream>
#include <cstdlib>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <queue>
#include <map>
#include <vector>
#define N 100005
using namespace std;
int n,p=;
long long ksm(long long x,long long z)
{
long long ans=;
while(z)
{
if(z&)
{
ans*=x;
ans%=p;
}
x*=x;x%=p;
z>>=;
}
return ans;
}
int zz,ss[];
struct no{
int left,right,mid;
long long data,pp;
}node[N*];
void build(int left,int right,int x)
{
node[x].left=left,node[x].right=right;
node[x].pp|=(<<1ll);
if(left==right)
{
node[x].data=;
return;
}
int mid=(left+right)>>;
node[x].mid=mid;
build(left,mid,x*);
build(mid+,right,*x+);
node[x].data=node[*x].data*node[*x+].data;
node[x].data%=p;
}
void change(int to,int x,long long z)
{
if(node[x].left==node[x].right)
{
node[x].data=z;
node[x].pp=;
for(int i=;i<=zz;i++)
{
if(z%ss[i]==) node[x].pp|=(1ll<<(i-1ll));
}
return;
}
int mid=node[x].mid;
if(to>mid)change(to,*x+,z);
else change(to,*x,z);
node[x].data=node[*x].data*node[*x+].data;
node[x].data%=p;
node[x].pp=node[*x].pp|node[*x+].pp;
}
long long pp;
long long get(int left,int right,int x)
{
if(node[x].left==left&&node[x].right==right)
{
pp|=node[x].pp;
return node[x].data;
}
int mid=node[x].mid;
if(left>mid)return get(left,right,*x+);
else if(right<=mid)return get(left,right,*x);
else return get(left,mid,*x)*get(mid+,right,*x+)%p;
}
long long ni[];
void init()
{
for(int i=;zz<;i++)
{
zz++;
ss[zz]=i;
for(int j=;j<=sqrt(i);j++)
{
if(i%j==)
{
ss[zz]=;
zz--;
break;
}
}
}
for(int i=;i<=;i++)ni[i]=ksm(ss[i],p-);
}
int main()
{
init();
scanf("%d",&n);
build(,,);
for(int i=;i<=n;i++)
{
int op;
scanf("%d",&op);
if(op)
{
long long x,y;
scanf("%lld%lld",&x,&y);
change(x,,y);
}
else
{
long long x,y;
pp=;
scanf("%d%d",&x,&y);
long long pro=get(x,y,);
long long ans=pro;
for(int i=;i<=zz;i++)
{
if(pp&(1ll<<(i-1ll)))
{
ans*=ni[i];
ans%=p;
ans*=(ss[i]-);
ans%=p;
}
}
printf("%lld\n",ans);
}
}
return ;
}
Bzoj 3813 奇数国 题解 数论+线段树+状压的更多相关文章
- HYSBZ - 3813 奇数国 欧拉函数+树状数组(线段树)
HYSBZ - 3813奇数国 中文题,巨苟题,巨无敌苟!!首先是关于不相冲数,也就是互质数的处理,欧拉函数是可以求出互质数,但是这里的product非常大,最小都2100000,这是不可能实现的.所 ...
- [BZOJ 3813]奇数国
3813: 奇数国 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 736 Solved: 416[Submit][Status][Discuss] ...
- hdu 5023 线段树+状压
http://acm.hdu.edu.cn/showproblem.php?pid=5023 在片段上着色,有两种操作,如下: 第一种:P a b c 把 a 片段至 b 片段的颜色都变为 c . 第 ...
- POJ:2777-Count Color(线段树+状压)
Count Color Time Limit: 1000MS Memory Limit: 65536K Description Chosen Problem Solving and Program d ...
- POJ 3468 线段树+状压
题意:给你n个数,有对区间的加减操作,问某个区间的和是多少. 思路:状压+线段树(要用lazy标记,否则会TLE) //By SiriusRen #include <cstdio> #in ...
- HDU_3071 Gcd & Lcm game 【素数分解 + 线段树 + 状压】
一.题目 Gcd & Lcm game 二.分析 非常好的一题. 首先考虑比较暴力的做法,肯定要按区间进行处理,对于$lcm$和$gcd$可以用标准的公式进行求,但是求$lcm$的时候是肯定 ...
- poj2777Count Color——线段树+状压
题目:http://poj.org/problem?id=2777 状压每个颜色的选择情况,取答案时 | 一番: 注意题目中的区间端点可能大小相反,在读入时换一下位置: 注意pushdown()中要l ...
- 【bzoj4006】[JLOI2015]管道连接 斯坦纳树+状压dp
题目描述 给出一张 $n$ 个点 $m$ 条边的无向图和 $p$ 个特殊点,每个特殊点有一个颜色.要求选出若干条边,使得颜色相同的特殊点在同一个连通块内.输出最小边权和. 输入 第一行包含三个整数 n ...
- Bzoj 1756: Vijos1083 小白逛公园 线段树
1756: Vijos1083 小白逛公园 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 1021 Solved: 326[Submit][Statu ...
随机推荐
- Android项目实战(一): SpannableString与SpannableStringBuilder
原文:Android项目实战(一): SpannableString与SpannableStringBuilder 前言: 曾经在一些APP中的一些类似“帮助”“关于”的界面看过一行文字显示不同的颜色 ...
- Linux学习之“fork函数”
n返回值: fork函数调用一次,但是返回两次:在子进程中返回0,在父进程中返回子进程ID,出错返回-1.通过返回值,可以确定是在父进程还是子进程中. n子进程和父进程继续执行fork调用之后的指令. ...
- 快速写入Xml文件
我们在做一些操作的时候会需要生成日志,Xml文件就是我们常用的一种日志文件. 普通操作Xml文件的代码遇到大数据量的话就很慢了. 用这个生成Xml文件的话,即使数据量很大,也很快 private vo ...
- phpexcel导出超过26列解决方案
原文:phpexcel导出超过26列解决方案 将列的数字序号转成字母使用,代码如下: PHPExcel_Cell::stringFromColumnIndex($i); // 从o,1,2,3,.. ...
- 创建dll动态链接库,并使用java调用
参考文章:http://www.cnblogs.com/matthew-2013/p/3480296.html http://blog.csdn.net/g710710/article/details ...
- C#跳转语句
1.break 退出直接封闭它的switch.while.do.for或foreach语句. 当有嵌套时,break只退出最里层的语句块. break不能跳出finally语句块. 2.continu ...
- Ptypes一个开源轻量级的c++库,包括对一些I/O操作、网络通信、多线程和异常处理的封装
C++开源项目入门级:Ptypes Ptypes一个开源轻量级的c++库,包括对一些I/O操作.网络通信.多线程和异常处理的封装.虽然代码有限,包括的内容不少,麻雀虽小,五脏俱全. 提高: ...
- 腾讯移动Web整体解决方案Spirit
Spirit(勇气号),美国航天局NASA派往Mars(火星)的第一艘探测器.移动Web开发是一块新的领域,甚至有很多坑,这一点与人类从未踏上的Mars(火星)相似.为了避免开发者重复遇到相同的问题, ...
- 【DRP】-Dao层常用功能代码:增删改查
本系列博客内容为:做DRP系统中Dao层常用功能. 该项目采用MVC架构 C(Controller)控制器,主要职责;1.取得表单参数:2.调用业务逻辑:3.转向页面 M(Model)模型,主要职责: ...
- QT中获取选中的radioButton的两种方法(动态取得控件的objectName之后,对名字进行比较)
QT中获取选中的radioButton的两种方法 QT中要获取radioButton组中被选中的那个按钮,可以采用两种如下两种办法进行: 方法一:采用对象名称进行获取 代码: 1 QRadioBu ...