【FJWC2018】最大真因数
题面
Description
一个合数的真因数是指这个数不包括其本身的所有因数,
例如 6 的正因数有1, 2, 3, 6,其中真因数有 1, 2, 3。
一个合数的最大真因数则是这个数的所有真因数中最大的一个,例如 6 的最大真因数为 3。
给定正整数 l 和 r,请你求出 l 和 r 之间(包括 l 和 r)所有合数的最大真因数之和。
Input
输入共一行,包含两个正整数 l 和 r。保证 l ≤ r。
Output
输出共一行,包含一个整数,表示 [l,r] 内所有合数的最大真因数之和。
Sample Input
1 10
Sample Output
17
【样例 1 解释】
在 1 至 10 之间的合数有 4, 6, 8, 9, 10,
它们的最大真因数分别为 2, 3, 4, 3, 5,
因此最大真因数之和为 2 + 3 + 4 + 3 + 5 = 17。
Hint
【样例 2 输入】
101 1000
【样例 2 输出】
163446
【样例 3 输入】
180208 975313
【样例 3 输出】
151642139152
【样例 4 输入】
339762200 340762189
【样例 4 输出】
112318862921546
【样例 5 输入】
2500000000 5000000000
【样例 5 输出】
3094668961678105770
题目分析
要求合数的最大真因数,相当于求合数除以其最小质因子。
再Min_25筛求素数和的过程中:
\begin{cases}
g(n,j-1)&P_j^2> n\\
g(n,j-1)-f(P_j)\cdot[g(\frac{n}{P_j},j-1)-\sum_{i=1}^{j-1}f(P_i)]&P_j^2\leq n
\end{cases}
\]
其中
\]
求得的便是最小质因子为\(P_j\)的合数之和。
我们只需在处理\(g\)的时候统计答案即可。
代码实现
#include<iostream>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<cstdio>
#include<iomanip>
#include<cstdlib>
#define MAXN 0x7fffffff
typedef unsigned long long LL;
const int N=250005;
using namespace std;
inline LL Getint(){register LL x=0,g=1;register char ch=getchar();while(!isdigit(ch)){if(ch=='-')g=-1;ch=getchar();}while(isdigit(ch)){x=x*10+ch-'0';ch=getchar();}return x*g;}
int prime[N],tot;bool vis[N];
LL sqr,w[N],g[N],sp[N];
int id1[N],id2[N],m;
void Pre(int n){
for(int i=2;i<=n;i++){
if(!vis[i])prime[++tot]=i,sp[tot]=sp[tot-1]+i;
for(int j=1;j<=tot&&1ll*i*prime[j]<=n;j++){
vis[i*prime[j]]=1;
if(i%prime[j]==0)break;
}
}
}
LL Solve(LL n){
tot=m=0;
sqr=sqrt(n),Pre(sqr);
for(LL i=1,j;i<=n;i=j+1){
j=n/(n/i),w[++m]=n/i;
g[m]=w[m]*(w[m]+1)/2-1;
if(w[m]<=sqr)id1[w[m]]=m;else id2[j]=m;
}
LL ans=0;
for(int j=1;j<=tot;j++){
for(int i=1;i<=m&&(LL)prime[j]*prime[j]<=w[i];i++){
int k=(w[i]/prime[j]<=sqr)?id1[w[i]/prime[j]]:id2[n/(w[i]/prime[j])];
if(i==1)ans+=g[k]-sp[j-1];
g[i]-=prime[j]*(g[k]-sp[j-1]);
}
}
return ans;
}
int main(){
LL l=Getint(),r=Getint();
cout<<Solve(r)-Solve(l-1);
return 0;
}
【FJWC2018】最大真因数的更多相关文章
- BZOJ-5244 最大真因数(min25筛)
题意:一个数的真因数指不包括其本身的所有因数,给定L,R,求这个区间的所有数的最大真因数之和. 思路:min25筛可以求出所有最小因子为p的数的个数,有可以求出最小因子为p的所有数之和. 那么此题就是 ...
- Project Euler 95:Amicable chains 亲和数链
Amicable chains The proper divisors of a number are all the divisors excluding the number itself. Fo ...
- Python 计算当真因子个数为偶数个时为幸运数,计算区间内幸运数之和
晚饭后朋友发来个问题,正好无事做,动手写了一下 若一个正整数有偶数个不同的真因子,则称该数为幸运数.如4含有2个真因子为 1 和 2 .故4是幸运数.求[2,100]之间的全部幸运数之和. 常规思路 ...
- POJ3292&&2115
这两道题还是比较简单的,没有什么难度 不过归在数论这个专题里我还是比较认同的,多少有些关系 3292 题目大意:给你一个范围n,让你求出这个范围内所有形式类似\(4k+1(k为正整数)\)的数中的H- ...
- 【FCS NOI2018】福建省冬摸鱼笔记 day1
省冬的第一天. 带了本子,笔,一本<算法导论>就去了.惊讶于为什么同学不带本子记笔记. 他们说:“都学过了.”,果然这才是巨神吧. 第一天:数论,讲师:zzx 前几页的课件挺水,瞎记了点笔 ...
- c经典算法
1. 河内之塔 说明 河内之塔(Towers of Hanoi)是法国人M.Claus(Lucas)于1883年从泰国带至法国的,河内为越战时 北越的首都,即现在的胡志明市:1883年法国数学家 Ed ...
- 相亲数--Python
想亲数:在遥远的古代,人们发现某些自然数之间有特殊的关系:如果两个数a和b,a的所有除本身以外的因数之和等于b,b的所有除本身以外的因数之和等于a,则称a,b是一对相亲数 code: def sumF ...
- Java经典算法大全
1.河内之塔.. 2.Algorithm Gossip: 费式数列. 3. 巴斯卡三角形 4.Algorithm Gossip: 三色棋 5.Algorithm Gossip: 老鼠走迷官(一) 6. ...
- 求n的因子个数与其因子数之和
方法一:朴素算法:O(n). #include<bits/stdc++.h> using namespace std; int get_num(int n){ ; ;i<=n;++i ...
随机推荐
- 前端,用js根据一个对象,去除另个对象中重复的元素
这里的应用场景是,两个div盛放待选项目和已选项目,如下图 <div class="col-xs-6 col-sm-6 col-md-6 col-lg-6"> < ...
- 高德地图的权限Activity代码
/** * */package com.amap.location.demo; import java.lang.reflect.Method;import java.util.ArrayList;i ...
- Hibernate与Mybatis的简单区别
数据库连接创建.释放频繁造成系统的资源浪费从而影响系统性能,可以使用数据库连接池解决此问题,之前的java应用程序sql语句也是写在java代码中造成系统可维护性差,实际应用的sql变化较大,sql变 ...
- 【操作】Linux快捷键
- YII 中加入短信接口的函数
public function smsto($telphone,$message) { //短信接口用户名 $uid,如果没有或不能发送请与客服联系 $uid = 'zyd'; //短信接口密码 $p ...
- 微信支付完成 vue 页面不跳转问题
遇到的问题是 vue 调用微信支付 回调成功以后,页面路由不跳转. 解决的办法是用window.location.href /** * @method 支付费用方法 * @param data:后台返 ...
- 2018——2019 20165239Exp9 Web安全基础
Exp9 Web安全基础 一:基础问题回答 (1)SQL注入攻击原理,如何防御 •原理:它是利用现有应用程序,将恶意的SQL命令注入到后台数据库引擎执行的能力,它可以通过在Web表单中输入恶意SQL语 ...
- 为什么 Go 语言把类型放在后面
不是为了与众不同.而是为了更加清晰易懂. Rob Pike 曾经在 Go 官方博客解释过这个问题(原文地址:http://blog.golang.org/gos-declaration-syntax) ...
- [Go语言]cgo用法演示
经历了数十年发展的C语言,各种各样的现成的库已经非常丰富.通过cgo,可以在Go语言中使用C语言代码,充分利用好现有的“轮子”. 本文所有代码,在下述环境中调试通过: Windows 8.1 ...
- switch type 类型判断
golang 语言中 也有 类是 javascript 的 typeof 判断类型的 方法 比如 func (a interface{}){ //第一种 if inst,ok:=a.(TypeA);o ...