Factors of Factorial AtCoder - 2286 (N的阶乘的因子个数)(数论)

Problem Statement

 

You are given an integer N. Find the number of the positive divisors of N!, modulo 10^9+7.

Constraints

 

  • 1≤N≤10^3

Input

 

The input is given from Standard Input in the following format:

N

Output

 

Print the number of the positive divisors of N!, modulo 10^9+7.

Sample Input 1

 

3

Sample Output 1

 

4

There are four divisors of 3! =6123 and 6. Thus, the output should be 4.

Sample Input 2

 

6

Sample Output 2

 

30

Sample Input 3

 

1000

Sample Output 3

 

972926972


题意: 
  给你一个整数N,求N的结成N!的因子个数,并对1E9+7取模

首先我们应该知道这个的一个性质。
N!=1*2*3*4~~~*n
N!=(2*4*6*8...n)*(1*3*5*7.....*(n-1))
N!=2^(n/2)*(n/2)!*(1*3**5*7*...*(n-1))
所以N规模的问题转换为N/2规模了,原来求N!含有素数2的个数,等价于求(N/2)!含有素数2的个数加上N/2了。上面是N为偶数的算法,N为奇数时也是一样。
递推式f(n, 2) = f(n/2, 2) + n/2,表示n!中2的个数。
同理,推出 f(n, p) = f(n/p, p) + n/p,表示n!中素数p的个数
 
int f(int n, int p)
{if(n==0)return 0;return f(n/p,p) + n/p;
}

再介绍下唯一分解定理,
即大于1的任意整数,都可以用质数的次幂的积来表示出来,而且这个表示是唯一的,所以叫唯一分解定理。

这样我们只需要先处先线性筛把质数都筛出来,然后直接logN来唯一分解出N,


首先来看这样的一个问题,我们要求N的所有因子个数,我们知道可以sqrt(n)时间复杂度的解决方案,但是显然太慢了。
我们还有另外一个定理,将N进行唯一分解后,他的所有因子的个数,就是它的质因子的幂次+1的乘积。
例如:
N= p1^t1 * p2^t2 * p3^t3* … * pk^tk(其中,p1, p2, … pk为素数)
那么N的所有因子个数就是num=(t1+1)*(t2+1)*(t3+1)*...*(tk+1)

借助这个定理,我们通过最上面提到的方法把N!唯一分解,
然后就很容易的求出它的所有因子个数。

细节见代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <queue>
#include <stack>
#include <map>
#include <set>
#include <vector>
#include <iomanip>
#define ALL(x) (x).begin(), (x).end()
#define dll(x) scanf("%I64d",&x)
#define xll(x) printf("%I64d\n",x)
#define sz(a) int(a.size())
#define all(a) a.begin(), a.end()
#define rep(i,x,n) for(int i=x;i<n;i++)
#define repd(i,x,n) for(int i=x;i<=n;i++)
#define pii pair<int,int>
#define pll pair<long long ,long long>
#define gbtb ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
#define MS0(X) memset((X), 0, sizeof((X)))
#define MSC0(X) memset((X), '\0', sizeof((X)))
#define pb push_back
#define mp make_pair
#define fi first
#define se second
#define eps 1e-6
#define gg(x) getInt(&x)
#define db(x) cout<<"== [ "<<x<<" ] =="<<endl;
using namespace std;
typedef long long ll;
ll gcd(ll a,ll b){return b?gcd(b,a%b):a;}
ll lcm(ll a,ll b){return a/gcd(a,b)*b;}
ll powmod(ll a,ll b,ll MOD){ll ans=1ll;while(b){if(b&1)ans=ans*a%MOD;a=a*a%MOD;b>>=1;}return ans;}
inline void getInt(int* p);
const int maxn=100010;
const int inf=0x3f3f3f3f;
/*** TEMPLATE CODE * * STARTS HERE ***/
bool noprime[maxn];
std::vector<int> p;
ll pf[122][3];
int init()
{MS0(noprime);p.clear();int m=(int)(sqrt(maxn+0.5));repd(i,2,m){if(!noprime[i]){for(int j=i*i;j<=maxn;j+=i){noprime[j]=1;}}}repd(i,2,maxn){if(!noprime[i]){p.pb(i);}}return p.size();
}
int getprifac(ll n,int len)
{int pos=0;for(int i=0;p[i]*p[i]<=n&&i<len;i++){if(n%p[i]==0){pf[++pos][0]=p[i];pf[pos][1]=0;while(n%p[i]==0){pf[pos][1]++;n/=p[i];}}}if(n>1){pf[++pos][0]=n;pf[pos][1]=1;}return pos;
}
ll getnum(ll num,ll x)
{if(!num){return 0;}else{return num/x+getnum(num/x,x);}
}
const ll mod = 1e9+7ll;
int main()
{//    freopen("C:\\Users\\DH_M\\Desktop\\code_io\\in.txt.txt","r",stdin);//    freopen("C:\\Users\\DH_M\\Desktop\\code_io\\out.txt.txt","w",stdout);
    ll n;cin>>n;int len=init();ll ans=1ll;rep(i,0,len){if(p[i]>n)break;ll cnt=getnum(n,p[i]);ans*=(cnt+1ll);ans=(ans+mod)%mod;}cout<<ans<<endl;return 0;
}inline void getInt(int* p) {char ch;do {ch = getchar();} 
while (ch == ' ' || ch == '\n');if (ch == '-') {*p = -(getchar() - '0');
while ((ch = getchar()) >= '0' && ch <= '9') {*p = *p * 10 - ch + '0';}}
else {*p = ch - '0';while ((ch = getchar()) >= '0' && ch <= '9') 
{*p = *p * 10 + ch - '0';}}}
 

 

 

转载于:https://www.cnblogs.com/qieqiemin/p/10547205.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/569633.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VS Code编译Python

一、想要编译Python我们首先要安装python&#xff0c;进入官网下载python3&#xff08;不要下载python2.7&#xff0c;不就之后就不会再使用低版本的python了&#xff09; 二、配置环境变量 三、在VS Code中添加插件&#xff0c;记得添加完点击重新加载插件&#xff0c;或…

JAVA学习笔记_五JAVA开发中的WEB前端技术

css 字体属性: font-size font-style font-family font-weight font 设置字体font-family时&#xff0c;中文、英文字体设置时的顺序&#xff0c;英文在前中文在后&#xff1b; font-size&#xff1a;常用单位px&#xff0c;也用in、cm、mm、pt、pc&#xff0c;这几个简…

VS Code编译C/C++

C/C环境的配置要比python的复杂许多&#xff0c;好几个配置文件要写。 一、编译C/C的环境一般都是集成在我们的编辑器中的&#xff0c;如果电脑上有codeblock和dev c的读者可以去安装路径下找找MinGW文件夹&#xff0c;可以不用重复下载。而没有的读者则需要下载MinGW 二、配置…

H5的Video事件,控制方法,及监听

1.标签基本属性 src &#xff1a;视频的属性 poster&#xff1a;视频封面&#xff0c;没有播放时显示的图片preload&#xff1a;预加载autoplay&#xff1a;自动播放loop&#xff1a;循环播放controls&#xff1a;浏览器自带的控制条width&#xff1a;视频宽度 height&#xff…

Hexo+GitHub 快速搭建个人博客(一)---- 基本部署

前期准备&#xff1a; 1.Git shell 2.node.js 3.在github上创建一个仓库&#xff0c;仓库命名格式为xxx.github.io 一、安装Hexo cd进入自己想要安装的目录下&#xff0c;执行下面的命令 npm install hexo-cli -g 升级Hexo npm update hexo -g 卸载Hexo 如果安装过程中…

Gym - 101755G Underpalindromity (树状数组)

Let us call underpalindromity of array b of length k the minimal number of times one need to increment some elements bj by 1 so that the array b would become a palindrome, that is, b1  bk, b2  bk - 1, and so on. The array of length n, consisting of i…

Hexo+GitHub 快速搭建个人博客(二)---- 域名解析

前期准备&#xff1a; 备案的国内域名或者国外域名 &#xff08;后面会解释为什么&#xff0c;这里以阿里云域名为例&#xff09; 一、将个人域名与GitHub博客绑定 我们在Hexo目录下的source子目录内创建一个txt文件&#xff0c;内容写自己的域名&#xff0c;这里可以是一级…

.net core consul 服务配置 服务发现 服务健康检测 服务变更加载

准备环境 安装consul之后 1. 创建一个.net core webapi 举例为UsercenterService 2. nuget引用Consul组件 https://github.com/PlayFab/consuldotnet 3. 创建配置实体类 &#xff08;后面涉及功能介绍时候再解释属性含义&#xff09; 1 public class AppSettings2 {3 …

Hexo+GitHub 快速搭建个人博客(三)---- 改变主题

前期准备&#xff1a; 基本的Linux命令 基本的GitHub命令 Hexo有多种博客框架&#xff0c;在 https://hexo.io/themes/ 里可以找到非常多优秀的博客框架&#xff0c;而且都是免费的。 首先大家可以去找一款自己喜欢的框架&#xff0c;可以选择浏览和直接进入GitHub进行fork …

hdu1814 Peaceful Commission

题目链接&#xff1a;戳我 菜得不行了&#xff0c;直到今天才刚开始学2-SAT。。。。 2-SAT的模板&#xff0c;因为是求最小字典序&#xff0c;所以只能用上限为\(O(nm)\)的最暴力的方法来做。。。 #include<iostream> #include<cstring> #include<cstdio> #i…

Vue入门 ---- 组件式开发

##组件 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><meta http-equiv"X-UA-Compatible" conten…

/usr/bin/python^M: 解释器错误: 没有那个文件或目录

【1】问题现象 执行python脚本&#xff0c;提示错误&#xff1a;/usr/bin/python^M: 解释器错误: 没有那个文件或目录 【2】原因分析 大多数是因为脚本文件在windows下编辑过。在windows下&#xff0c;每一行的结尾是\r\n&#xff0c;而在linux下文件的结尾是\n。 那么&#xf…

Vue入门 ---- 组件通信

##组件通信&#xff1a; 子组件获取父组件的数据父组件获取子组件的数据平行组件之间的通信vue2.0中用子组件修改父组件数据报错问题一定需要通过子组件修改父组件 子组件获取父组件的数据 通过子组件中的属性props&#xff0c;以与父组件数据的绑定。&#xff08;注意&#x…

[51nod1201]整数划分

题目链接&#xff1a; 51nod1201 神仙DP 设\(f[i][j]\)表示\(i\)分成\(j\)个数的划分数&#xff0c;如何转移&#xff1f; 有转移式&#xff1a;\(f[i][j]f[i-j][j-1]f[i-j][j]\) 为什么呢&#xff1f;第一种是先加一个划分出来的数\(1\)&#xff0c;但是为了和之前的所有数不一…

Vue入门 ---- vue-loader 、vue-cli

简介&#xff1a; vue-loader&#xff0c;来源于css-rouder、url-loader、html-loader… 后台node.js–>require exports等都是基于模块的开发 broserify 较早的模块加载器&#xff0c;但是只能加载js webpack&#xff0c;模块加载器&#xff0c;一切东西皆模块&#xff0c;…

Python档案袋( 命令行操作 及 Os与Shutil文件操作补充 )

调用系统命令 import os#调用系统命令&#xff0c;输出只能输出到屏幕上&#xff0c;不能用变量接收 os.system("ipconfig")#调用系统命令&#xff0c;并把执行结果存到变量中 resos.popen("ipconfig").read() print(res) OS模块文件操作 简单的文件和目录…

Vue入门---- vue-router

#简介&#xff1a; vue-router官网 用 Vue.js vue-router 可以快速创建SPA&#xff08;单页应用程序&#xff09;&#xff0c;是非常简单的。使用 Vue.js &#xff0c;我们已经可以通过组合Component来组成应用程序。 引入 vue-router 的过程&#xff1a;将组件(components)映…

Vue入门 ---- vuex

##简介 Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态&#xff0c;并以相应的规则保证状态以一种可预测的方式发生变化。 vuex分为三大部分&#xff1a; state&#xff0c;驱动应用的数据源&#xff1b; view&#xff0c;以声…

2 Class类

在程序运行期间&#xff0c;Java运行时系统始终为所有的对象维护一个被称为运行时地类型标识。这个信息跟踪着每个对象所属地类。虚拟机 利用运行时类型信息选择相应地方法执行。 然而&#xff0c;可以通过专门地Java类访问这些信息。保存这些信息地类称为Class。这个名字很容易…

Dijkstra算法(c++版)

最短路径&#xff08;DP的应用&#xff09; 单源最短路径&#xff0c;不允许出现负环 核心思想&#xff1a;更新估算距离&#xff0c;松弛 δ(u,v)≤δ(u,x)δ(x,v)\delta(u, v) \leq \delta(u, x) \delta(x, v) δ(u,v)≤δ(u,x)δ(x,v) 时间复杂度与采用的数据结构有关&…