【GDOI2016模拟3.16】幂
  • \(X\in[1,A],Y\in[1,B]\),问:\(x^y\)的不用取值个数.

  • \(A,B\)都是\(10^9\)级别.

  • 然后我们开搞.

  • 首先,假设一个合法的\(x\)可以表示为\(x=\prod p_i^{q_i}\),那么令\(d=gcd(q_1,q_2...q_k)\)

  • 假设\(d>1\),显然我们不需要单独考虑,因为它可以继续化简,我们找到最简的那个数然后去一次性处理.

  • 那么此时所有情况都变成了\(d=1\).

  • 此时再分两种情况讨论,因为我们现在实际上把问题转化为了:

    \(x\in[1,A]\),\(y\in [1,B]\),求\((c^x)^y\)的不同个数.

  • 然后这个问题显然当\(x>\sqrt{A}\)时贡献就是\(B\)。

  • 所以题目转化为:

    在\(x\in[1,\sqrt{A}],y\in[1,B]\)时,\((c^x)^y\)的不同个数.

  • 于是我们可以正难则反,计算一下不合法的个数,假设\(k={log_x}^n\),那么问题又可以转化为:

    \(x\in[1,k],y\in[1,B]\),\(xy\)的相同个数.

  • 于是这个问题值得思考一下.

  • 咱有一个经典套路:分块计算;

  • 即把总范围\([1,KB]\)变成\(K\)块,每一块都长的像这样的形式:

\[[(i-1)B+1,iB] | (1\le i \le K)
\]

  • 那么现在单独考虑每一块的贡献.

  • 然后假设我们现在处理第\(i\)个块,那么如果其中某一个数可以被表示为\(x*y\)的形式.

  • 则必定存在一个\(d\in [i,k]\),满足\(d|x*y\).

  • 因为这样子就必定能满足\(x\in [1,K],y\in [1,B]\)这两个条件.

  • 所以现在题目再次被转化:

    等价于我们要求在区间\([(i-1)B+1,iB]\)范围内有多少个数是\([i,k]\)区间中某一个数的倍数.

  • 这次转化以后我们发现问题就变得熟悉了...

  • 因为\(B\)比较大,\(k\)貌似小,所以,,,, 这TM容斥一下不就好了??

  • 但是,我们发现,\(k\)最大可能为\(30\),这意味着,\(2^{30}\)是接受不了的...

  • 但是我们很容易想到,如果当乘上一个数的lcm没有变化之后,就不需要去弄.

  • 这样子的话时间一下子就降了下来,反正怎么打都能过~

#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath> #define ll long long
#define F(i, a, b) for (ll i = a; i <= b; i ++)
#define sqr(x) ((x) * (x)) const ll N = 5e5; ll ans, sum; ll A, B, up, P[N]; bool vis[N]; using namespace std; void Init() {
#ifndef ONLINE_JUDGE
freopen("data.in", "r", stdin);
#endif scanf("%lld%lld", &A, &B); up = int(sqrt(A)) + 1; ans = 1LL * (A - 1) * B + 1;
} void GetPrime() {
F(i, 2, N - 1) {
if (!vis[i])
P[++ P[0]] = i;
F(j, 1, P[0]) {
if (P[j] * i >= N) break;
vis[P[j] * i] = 1;
if (i % P[j] == 0) break;
}
}
} ll gcd(ll x, ll y){
return y == 0 ? x : gcd(y, x % y);
} void dfs(ll x, ll v, ll st, ll en, ll g, ll k) {
if (x > k) {
sum += 1LL * (en / v - st / v) * g;
return;
}
if (x != gcd(v, x)) {
dfs(x + 1, v * x / gcd(v, x), st, en, g * (- 1), k);
dfs(x + 1, v, st, en, g, k);
}
} ll Solve(ll x) {
ll cnt = -1;
for (ll tmp = 1; tmp <= A; tmp *= x, cnt ++); sum = 0;
F(i, 2, cnt)
dfs(i, 1, (i - 1) * B, i * B, 1, cnt); return sum;
} void Doit() {
F(i, 2, up) {
ll tmp = i, yes = 0;
F(j, 1, P[0]) {
if (sqr(P[j]) > i) break; ll cnt = 0;
while (tmp % P[j] == 0) tmp /= P[j], cnt ++; yes = gcd(yes, cnt);
if (yes == 1) break;
} if (tmp > 1 || yes == 1)
ans -= Solve(i);
} printf("%lld\n", ans);
} int main() {
Init(); GetPrime(); Doit();
}

【GDOI2016模拟3.16】幂(容斥 + 模型复杂转化)的更多相关文章

  1. bzoj 3930: [CQOI2015]选数【快速幂+容斥】

    参考:https://www.cnblogs.com/iwtwiioi/p/4986316.html 注意区间长度为1e5级别. 则假设n个数不全相同,那么他们的gcd小于最大数-最小数,证明:则gc ...

  2. [CSP-S模拟测试]:阴阳(容斥+计数+递推)

    题目传送门(内部题16) 输入格式 第一行两个整数$n$和$m$,代表网格的大小.接下来$n$行每行一个长度为$m$的字符串,每个字符若为$W$代表这个格子必须为阳,若为$B$代表必须为阴,若为$?$ ...

  3. CF285E Positions in Permutations(dp+容斥)

    题意,给定n,k,求有多少排列是的 | p[i]-i |=1 的数量为k. Solution 直接dp会有很大的后效性. 所以我们考虑固定k个数字使得它们是合法的,所以我们设dp[i][j][0/1] ...

  4. [BZOJ3622]已经没有什么好害怕的了(容斥DP)

    给定两个数组a[n]与b[n](数全不相等),两两配对,求“a比b大”的数对比“b比a大”的数对个数多k的配对方案数. 据说做了这题就没什么题好害怕的了,但感觉实际上这是一个套路题,只是很难想到. 首 ...

  5. hdu5072(鞍山regional problem C):容斥,同色三角形模型

    现场过的第四多的题..当时没什么想法,回来学了下容斥,又听学长讲了一讲,终于把它过了 题目大意:给定n个数,求全部互质或者全部不互质的三元组的个数 先说一下同色三角形模型 n个点 每两个点连一条边(可 ...

  6. HUST 1569(Burnside定理+容斥+数位dp+矩阵快速幂)

    传送门:Gift 题意:由n(n<=1e9)个珍珠构成的项链,珍珠包含幸运数字(有且仅由4或7组成),取区间[L,R]内的数字,相邻的数字不能相同,且旋转得到的相同的数列为一种,为最终能构成多少 ...

  7. 2017ACM暑期多校联合训练 - Team 8 1011 HDU 6143 Killer Names (容斥+排列组合,dp+整数快速幂)

    题目链接 Problem Description Galen Marek, codenamed Starkiller, was a male Human apprentice of the Sith ...

  8. [JZOJ 5894] [NOIP2018模拟10.5] 同余方程 解题报告(容斥)

    题目链接: http://172.16.0.132/senior/#contest/show/2523/0 题目: 题解:(部分内容来自https://blog.csdn.net/gmh77/arti ...

  9. [CSP-S模拟测试]:连连看(图论+容斥)

    题目传送门(内部题74) 输入格式 输入文件$link.in$ 第一行三个整数$n,m,k$,之间用空格隔开,$n,m$表示地图行数和列数,$k$表示每个方块周围相邻的位置(至多有$4$个,至少有$2 ...

随机推荐

  1. Cygwin 编译 ffmpeg

    1.在官网下载linux下的压缩包 https://ffmpeg.zeranoe.com/builds/source/ffmpeg/ffmpeg-3.2.4.tar.xz 2.进入cygwin,假定将 ...

  2. TreeView 节点拖拽

    public Form1() { InitializeComponent(); treeView1.AllowDrop = true; treeView1.ItemDrag += new ItemDr ...

  3. Python列表之班荆道故

    列表list初识 列表是python的基础数据类型之一 ,它是以[ ]括起来, 每个元素用' , '隔开而且可以存放各种数据类型: list列表的定义: list_ = []list_1 = [&qu ...

  4. HBase实践案例:知乎 AI 用户模型服务性能优化实践

    用户模型简介 知乎 AI 用户模型服务于知乎两亿多用户,主要为首页.推荐.广告.知识服务.想法.关注页等业务场景提供数据和服务, 例如首页个性化 Feed 的召回和排序.相关回答等用到的用户长期兴趣特 ...

  5. 磁盘缓存--YYCache 设计思路

    为了设计一个比较好的磁盘缓存,我调查了大量的开源库,包括 TMDiskCache.PINDiskCache.SDWebImage.FastImageCache 等,也调查了一些闭源的实现,包括 NSU ...

  6. Redtiger SQL注入练习(一)

    感觉会的东西太少了,以后要多练习,多写博客.要坚持学习,一定不能放弃,为梦想奋斗. redtiger  这个平台早就开始做了,但是才做到第4关.... 第一关: 打开题, 先随便试,后来发现点击 Ca ...

  7. Codeforces Round 1152 (div. 2)

    奇差.ABC三题,排名400. 首先是策略问题. 由于第一眼看到D的时候感觉不太会做,于是去看E. 一看到E这不欧拉回路吗,可做可做, 于是--我不会欧拉回路! 手推.推了半天啥也没弄出来, 于是大概 ...

  8. 2-STM32带你入坑系列(点亮一个灯--Keil)

    1-STM32带你入坑系列(STM32介绍) 首先是安装软件 这一节用Kei来实现,需要安装MDK4.7这个软件,怎么安装,自己百度哈.都学习32的人了,不会连个软件都不会安装吧....还是那句话 没 ...

  9. 为什么很多IT公司不喜欢进过培训机构的人呢?

    转载原文链接:https://www.cnblogs.com/alex3714/p/9105765.html 这几天在知乎看到一个问题“为什么很多IT公司不喜欢进过培训机构的人呢?” 身为老男孩的教学 ...

  10. Docker启动Get Permission Denied

    https://www.cnblogs.com/informatics/p/8276172.html 以下问题及解决方法都在Ubuntu16.04下,其他环境类似 问题描述 安装完docker后,执行 ...