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. ...
随机推荐
- weakHashMap 用法
WeakHashMap,此种Map的特点是: 当除了自身有对key的引用外,此key没有其他引用,那么GC之后此map会自动丢弃此值 当使用 WeakHashMap 时,即使没有显示的添加或删除任何元 ...
- Python2 安装教程
目录 1. 推荐阅读 2. 安装包下载 3. 安装步骤 1. 推荐阅读 Python基础入门一文通 | Python2 与Python3及VSCode下载和安装.PyCharm破解与安装.Python ...
- linux查看 inotify 提供的工具
[root@rsync-client-inotify ~]# ll /usr/local/bin/inotify* -rwxr-xr-x. 1 root root 38582 Jun 3 22:23 ...
- 编译安装github上的kafka_exporter项目
本文介绍的kafka_exporter是prometheus监控系统中针对kafka的一款监控插件,要使用这个监控插件,kafka的版本需要满足 0.10.1.0 及以上. 项目的github地址:h ...
- Oracle 索引数据字典、基于函数的索引
user_indexes 字典视图包含了索引名和唯一性, user_ind_columns视图包含了索引名.表名.以及列名 dba_indexes dba_ind_columns 同理 select ...
- 获取kingeditor编辑器内容
//初始化编辑器 var editorMini = KindEditor.create('.editor-mini',{ width : '70%', height : '250px', resize ...
- sys模块 json pickle模块
# sys模块# import sys# sys.path# sys.argv# sys.exit() # 脚本退出# print('[%s]'%('#'*1))# print('[%s]'%('#' ...
- Python---基础-小游戏用户猜数字
一.10 < cost < 50 的等价表达式 cost = 40 10 < cost < 50 (10 < cost) and (cost < 50) 二.使用i ...
- jenkins解决python不是内部命令
1.在 Windows 提示符下运行是没有问题. 2.把Jenkins项目配置中 python main.py 修改成python可执行文件全路径:D:\Python35\python.exe m ...
- ChainMap简单示例
ChainMap是dict的子类,拥有dict的所有功能, 感觉用它的地方吧??? from collections import ChainMap """ 相当于joi ...