Codeforces 1097D (DP+分解质因数)
题目
分析
考虑\(n=p^q\)且p为质数的情况
设dp[i][j]表示经过i次变化后数为\(p^j\)的概率
则初始值dp[0][q]=1
状态转移方程为\(dp[i][j]=\sum{}\frac{1}{u+1}dp[i-1][u],u\in[j,q]\)
最终的期望值\(E(p^q)=\sum dp[k][j] ·p^j ,j \in [0,q]\)
那么如果n不是某个质数的q次方呢
把n分解质因数,\(n={p_1}^{q_1}{p_2}^{q_2} \dots {p_n}^{q_n}\)
对于每一个\({p_i}^{q_i}\),求出期望再相乘即可
注意逆元最好要预处理,否则常数略大,总时间复杂度\(O(\sqrt n+k \log n)\)
代码
#include<iostream>
#include<cstdio>
#include<cstring>
#define maxn 205
#define maxk 10005
#define mod 1000000007
using namespace std;
inline long long fast_pow(long long x,long long k){
long long ans=1;
while(k){
if(k&1) ans=ans*x%mod;
x=x*x%mod;
k>>=1;
}
return ans;
}
inline long long inverse(long long x){
return fast_pow(x,mod-2);
}
long long n,k;
int cnt=0;
long long p[maxn];
int a[maxn];
void div(long long x){
long long i=2;
while(i*i<=x){
if(x%i){
i++;
}else{
p[++cnt]=i;
while(x%i==0){
a[cnt]++;
x/=i;
}
}
}
if(x!=1){
p[++cnt]=x;
a[cnt]=1;
}
}
long long inv[maxn];
long long dp[maxn];
long long dp_solve(long long p,int q){
memset(dp,0,sizeof(dp));
dp[q]=1;
for(int i=1;i<=k;i++){
for(int j=0;j<=q;j++){
long long tmp=0;
for(int u=j;u<=q;u++){
tmp=(tmp+dp[u]*inv[u+1]%mod)%mod;
}
dp[j]=tmp;
}
}
long long ans=0;
for(int i=0;i<=q;i++){
ans+=fast_pow(p,i)*dp[i]%mod;
ans%=mod;
}
return ans;
}
int main(){
scanf("%I64d %d",&n,&k);
div(n);
long long ans=1;
for(int i=0;i<=100;i++){
inv[i]=inverse(i);
}
for(int i=1;i<=cnt;i++){
ans*=dp_solve(p[i],a[i]);
ans%=mod;
}
printf("%I64d\n",ans%mod);
}
Codeforces 1097D (DP+分解质因数)的更多相关文章
- 【BZOJ4197】[Noi2015]寿司晚宴 状压DP+分解质因数
[BZOJ4197][Noi2015]寿司晚宴 Description 为了庆祝 NOI 的成功开幕,主办方为大家准备了一场寿司晚宴.小 G 和小 W 作为参加 NOI 的选手,也被邀请参加了寿司晚宴 ...
- Codeforces 893E Counting Arrays:dp + 线性筛 + 分解质因数 + 组合数结论
题目链接:http://codeforces.com/problemset/problem/893/E 题意: 共q组数据(q <= 10^5),每组数据给定x,y(x,y <= 10^6 ...
- 【bzoj4197】[Noi2015]寿司晚宴 分解质因数+状态压缩dp
题目描述 为了庆祝 NOI 的成功开幕,主办方为大家准备了一场寿司晚宴.小 G 和小 W 作为参加 NOI 的选手,也被邀请参加了寿司晚宴. 在晚宴上,主办方为大家提供了 n−1 种不同的寿司,编号 ...
- [CodeForces - 1225D]Power Products 【数论】 【分解质因数】
[CodeForces - 1225D]Power Products [数论] [分解质因数] 标签:题解 codeforces题解 数论 题目描述 Time limit 2000 ms Memory ...
- [Codeforces 1246B] Power Products (STL+分解质因数)
[Codeforces 1246B] Power Products (STL+分解质因数) 题面 给出一个长度为\(n\)的序列\(a_i\)和常数k,求有多少个数对\((i,j)\)满足\(a_i ...
- 【分解质因数】【树状数组】【快速幂】codeforces 2014 ACM-ICPC Vietnam National Second Round E. ACM
乘除都在150以内,分解质因数后发现只有35个,建立35个树状数组/线段树,做区间加.区间查询,最后快速幂起来. #include<cstdio> #include<cstring& ...
- Gym 101981J - Prime Game - [数学题][线性筛+分解质因数][2018-2019 ACM-ICPC Asia Nanjing Regional Contest Problem J]
题目链接:http://codeforces.com/gym/101981/attachments 题意: 令 $mul(l,r) = \prod_{i=l}^{r}a_i$,且 $fac(l,r)$ ...
- java分解质因数
package test; import java.util.Scanner; public class Test19 { /** * 分析:对n进行分解质因数,应先找到一个最小的质数k * 最小 ...
- 程序设计入门——C语言 第6周编程练习 1 分解质因数(5分)
1 分解质因数(5分) 题目内容: 每个非素数(合数)都可以写成几个素数(也可称为质数)相乘的形式,这几个素数就都叫做这个合数的质因数.比如,6可以被分解为2x3,而24可以被分解为2x2x2x3. ...
随机推荐
- ASE Alpha Sprint - backend scrum 9
本次scrum于2019.11.14再sky garden进行,持续15分钟. 参与人: Xin Kang, Zhikai Chen, Jia Ning, Hao Wang 请假: Lihao Ran ...
- 用C#实现获取文件夹大小的源代码
using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Tex ...
- tree 数状型结构显示目录下的内容
1. 命令功能 tree中文意思“树”,以树形结构显示目录内容.. 2. 语法格式 tree [option] [directory] tree 选项 目录 3. 使用范例 当最小化安装l ...
- flask之数据库的交互
一:关系型数据库 mysql Flask-SQLAlchemy管理关系型数据库. mysql数据库引擎:url : mysql://username:passowrd@hostname/databas ...
- No module named flask 导包失败,Python3重新安装Flask模块
在部署环境过程中,通过pip install -r requirements.txt安装包,结果启动项目时总是报错,显示没有flask模块,通过pip install flask还是不行,于是下载fl ...
- 笔记-CSS-e:nth-chid
1,CSS 2,
- python之路----操作系统的发展史
阅读目录 手工操作 —— 穿孔卡片 批处理 —— 磁带存储和批处理系统 多道程序系统 分时系统 实时系统 通用操作系统 操作系统的进一步发展 操作系统的作用 手工操作 —— 穿孔卡片 1946年第一台 ...
- swan.after
解释: swan.after可以拦截所有当前运行小程序对于API的调用,默认传入function时,只在API函数调用的返回阶段拦截.如果传入Object,则可以选择拦截的阶段(例如: 返回阶段.回调 ...
- c# 如何更改 WebBrowser所加载的 HTML元素(隐藏滚动条),并按照修改后的来呈现
如何更改 WebBrowser所加载的 HTML元素 方法1:在网页加载完毕后的事件里面添加代码,我这里只是修改网页不出现滚动条,因为滚动条我重写了. #region (private) 网页加载完成 ...
- 二叉搜索树第k个节点
/* struct TreeNode { int val; struct TreeNode *left; struct TreeNode *right; TreeNode(int x) : val(x ...