总感觉这位大仙讲的很清楚:bztminamoto

题意

题目讲的是求 l~r 内所有数的次大质因子,这里设 f(x) 为 x 的次大质因子

我们差分一下就变成求两个前缀和信息了

按照套路,我们考虑 S(i,j) 表示小于等于 i 的数内,所有最小质因子小于等于 p[j] 的次大质因子的前缀和

然后我们考虑将所有数分为合数与质数,那么质数的次大质因子为 0 ,无贡献

至于合数就是枚举它的最小质因子,那么枚举到 pk (k>=j)时,我们有两种情况:

  1. 当前的 pk 是次大质因子,那么最大质因子可能为 pk~ \(\lfloor {i\over p_k^{~e}} \rfloor\) 内任意的质数(e 满足: \(p_k^{e+1}<=i\))的可能 ,所以加上贡献这个范围内质数个数的贡献
  2. 当前 pk 不是次大质因子,那么我们加上 \(S({i\over p_k^{~e}},k+1)\) 即可
//by Judge
#include<bits/stdc++.h>
#define fp(i,a,b) for(register int i=(a),I=(b)+1;i<I;++i)
#define ll long long
using namespace std;
const int M=8e5+3;
typedef ll arr[M];
ll L,R,m,tot,blo; arr v,p,w,g,id1,id2;
inline void prep(int n){
for(int i=2;i<=n;++i){ if(!v[i]) p[++tot]=i;
for(int j=1;j<=tot&&p[j]*i<=n;++j)
{v[i*p[j]]=1; if(!(i%p[j])) break;}
}
}
inline ll S(ll n,ll x,int y){
if(x<=1||p[y]>x) return 0;
int k=x<=blo?id1[x]:id2[n/x]; ll res=0;
for(int i=y;i<=tot&&1ll*p[i]*p[i]<=x;++i){
ll t1=p[i],t2=t1*t1;
for(int e=1;t2<=x;++e,t1=t2,t2*=p[i]){
int k=x/t1<=blo?id1[x/t1]:id2[n/(x/t1)];
res+=S(n,x/t1,i+1)+p[i]*(g[k]-i+1);
}
} return res;
}
inline ll solv(ll n){ tot=m=0,prep(blo=sqrt(n)); // g 里存质因子个数的前缀和
for(ll l=1,r;l<=n;l=r+1) r=n/(n/l),w[++m]=n/l,g[m]=w[m]-1,
(w[m]<=blo)? id1[w[m]]=m:id2[n/w[m]]=m;
fp(j,1,tot) for(int i=1,k;1ll*p[j]*p[j]<=w[i]&&i<=m;++i)
k=w[i]/p[j]<=blo?id1[w[i]/p[j]]:id2[n/(w[i]/p[j])],g[i]-=g[k]-j+1;
return S(n,n,1);
}
int main(){ cin>>L>>R,cout<<solv(R)-solv(L-1); return 0; }

UR#13 SRAND的更多相关文章

  1. UR #13 Ernd

    考试的时候没有注意到可以将(a,b)放在二维平面上之后旋转坐标系,使得转移变成树状数组二维偏序 这样就算我想出来了第二个转移的斜率优化也没有什么卵用啊(摔西瓜 设g(i)表示当前站在第i个水果下面且第 ...

  2. UR #13 Yist

    第一次打UR,打了一个半小时就弃疗了QAQ 这是我唯一一道考试的时候做出来的题目,其他两道连暴力都懒得写了 很容易发现对于每个要删除的点 我们找到左边第一个比他小的不用删除的点,右边第一个比他小的不用 ...

  3. uoj#188. 【UR #13】Sanrd(Min_25筛)

    题面 传送门 题解 这是一道语文题 不难看出,题目所求即为\(l\)到\(r\)中每个数的次大质因子 我们考虑\(Min\_25\)筛的过程,设 \[S(n,j)=\sum_{i=1}^nsec_p( ...

  4. uoj#187. 【UR #13】Ernd

    http://uoj.ac/problem/187 每个点只能从时间,b+a,b-a三维都不大于它的点转移过来,将点按时间分成尽量少的一些段,每段内三维同时非严格单调,每段内的点可能因为连续选一段而产 ...

  5. UOJ 188 【UR #13】Sanrd——min_25筛

    题目:http://uoj.ac/problem/188 令 \( s(n,j)=\sum\limits_{i=1}^{n}[min_i>=p_j]f(j) \) ,其中 \( min_i \) ...

  6. UOJ #188. 【UR #13】Sanrd

    Description 给定 \(\sum_{i=l}^r f[i]\) \(f[i]=\) 把 \(i\) 的每一个质因子都从小到大排列成一个序列(\(p_i^{c_i}\)要出现 \(c_i\) ...

  7. UOJ188. 【UR #13】Sanrd

    传送门 Sol 设 \(f_i\) 表示 \(i\) 的次大质因子 题目就是要求 \[\sum_{i=l}^{r}f_i\] 考虑求 \(\sum_{i=1}^{n}f_i\) 所求的东西和质因子有关 ...

  8. 「uoj#188. 【UR #13】Sanrd」

    题目 不是很能看懂题意,其实就是求\([l,r]\)区间内所有数的次大质因子的和 这可真是看起来有点鬼畜啊 这显然不是一个积性函数啊,不要考虑什么特殊的函数了 我们考虑Min_25筛的过程 设\(S( ...

  9. UOJ188. 【UR #13】Sanrd [min_25筛]

    传送门 思路 也可以算是一个板题了吧qwq 考虑min_25筛最后递归(也就是DP)的过程,要枚举当前最小的质因子是多少. 那么可以分类讨论,考虑现在这个质因子是否就是次大质因子. 如果不是,那么就是 ...

随机推荐

  1. 互斥量、条件变量与pthread_cond_wait()函数的使用,详解(二)

    1.Linux“线程” 进程与线程之间是有区别的,不过linux内核只提供了轻量进程的支持,未实现线程模型.Linux是一种“多进程单线程”的操作系统.Linux本身只有进程的概念,而其所谓的“线程” ...

  2. python Bootstarp框架和inconfont、font-awesome使用

    http://www.bootcss.com/ http://www.runoob.com/bootstrap/bootstrap-panels.html  查找基本的没问题 https://www. ...

  3. Docker记录-Docker部署记录

    1.Docker介绍 Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源. Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后 ...

  4. swagger使用一新手篇

    本文转自:http://javatech.wang/index.php/archives/74/ 先简单介绍下项目环境: JDK1.7 Spring 3.2.2 swagger-springmvc 1 ...

  5. sql 三表左外链接的2种写法【原】

    初始化语句 DROP TABLE student; ) )); ','bobo'); ','sisi'); ','gugu'); ','mimi'); DROP TABLE room; ) ),roo ...

  6. SpringMVC的概念和图解

    1.概念 Spring MVC起步:慕课网视频 SpringMVC架构浅析:参考 Spring详解(一)------概述 Spring架构简单描述 2.图片

  7. 前台ajax传参数,后台spring mvc用对象接受

    第二种方法:利用spring mvc的机制,调用对象的get方法,要求对象的属性名和传的参数名字一致(有兴趣的同学看 springmvc源码) 1.将参数名直接写成对象的属性名 $.ajax({ ur ...

  8. C语言memmove()函数: 复制内存内容(可以重叠的内存块)

    头文件:#include <string.h> memmove() 用来复制内存内容,其原型为: void * memmove(void *dest, const void *src, s ...

  9. 插入排序_JAVA

    public class Main { public static void main(String[] args) { int[] A = { 6, 4, 3, 5, 6, 2 }; for (in ...

  10. ImageView获取宽高

    在Android里放置一个ImageView im1,宽和高都是200.以下代码都是直接在OnCreate里使用. 1.在Android OnCreate里如果直接使用iv.GetWidth()返回值 ...