jzoj5813
tj:可以知道,隨意構造一個數列x,且x的第i位被n整除的方案是(約數個數)^2m,因為所有數可以隨便選,只要這個數能被n整除即可,方案為約數個數
設一個合法數列a的f值為x,則x小於n^m
假設所有數都取到n,則式子的值為n^(2m)。
我們可以另外構造一個數列a2,其每一個數的值為(n/a1,n/a2…..n/am*2)。
則這個數列的f值為n^(2m)/x。這個值大於n^m
所以可以知道每一個a小於n^m的情況都對應著一種a大於n^m的情況
設f值小於,等於,大於n^m的數列個數為a,b,c
則有a==c 且a+b+c==(約數個數)^2m
題目要求a+b的值,但是a不知道
如果我們求出f的值==n^m的情況,要比求出f的值小於n^m的情況要簡單的多,所以我們可以選擇求出f的值==n^m的情況
也就是說,我們求出b,有2*a=(約數個數)^2m-b,a=((約數個數)^2m-b)/2,a+b=((約數個數)^2m+b)/2,這樣子可以很快的計算出答案a+b
所以,本題實質上是要求出數列(a1,a2,……am*2)==n^m的方案
對於n的每一個因子,可以分開考慮,在結束以後再把所有方案乘起來
設現在要處理的因子為x,在n中有y個,那麼n^m中有m*y個
則問題轉化為了下面一個形式:
有2*m個不同籃子,m*y個蘋果,每一個籃子可以放0至y個蘋果,問有多少種方法,蘋果必須放完
可以dp,設f[i][j]表示在第i個籃子,當前放了j個蘋果的方案
則f[i][j]=sigma(f[i-1][j-k]),且(0<=k<=y),i<=m,j<=k,每一個狀態枚舉在當前的籃子裡放多少個蘋果
初值f[0][0]=1,最終將所有f[2*m][m*y]乘起來就是s2
再套用原來的公式可以得到答案
代碼
#include<bits/stdc++.h>
using namespace std;
#define mo 998244353
typedef long long ll;
ll n,m,f[210][4010],ans=1;
ll qp(ll x,ll y){
if(!y)return 1;
if(y==1)return x%mo;
ll r=qp(x,y>>1)%mo;
if(y%2==0)return r*r%mo;
else return r*r%mo*x%mo;
}
void cal(ll &x,ll y){
ll ct=0;
while(x%y==0){
x/=y;
ct++;
}
memset(f,0,sizeof(f));
f[0][0]=1;
for(ll i=1;i<=m*2;i++)
for(ll j=0;j<=ct*m;j++)
for(ll k=0;k<=min(ct,j);k++)
f[i][j]=(f[i][j]+f[i-1][j-k])%mo;
ans=(ans*f[2*m][ct*m])%mo;
}
int main(){
freopen("count.in","r",stdin);
freopen("count.out","w",stdout);
scanf("%lld%lld",&n,&m);
ll rt=sqrt(n),ct=0,tp=n;
for(ll i=1;i<=rt;i++)
if(n%i==0)ct+=(i*i==n?1:2);
for(ll i=2;i<=rt;i++)
if(tp%i==0)cal(tp,i);
if(tp>1)cal(tp,tp);
ct=qp(ct,m*2);
printf("%lld",(ct+ans)*qp(2,mo-2)%mo);
}
jzoj5813的更多相关文章
随机推荐
- 【329】word 替换文本高级用法
参考:查找和替换 Word 文档中的文本和其他数据 问题提出:由于在准备某个考试,然后题库中给了正确答案,对于单选题来说,可以直接替换成白色就看不见了,但是当遇到多选题的时候就麻烦了,毕竟 A/B/C ...
- 19.Remove Nth Node From End of List(List; Two-Pointers)
Given a linked list, remove the nth node from the end of list and return its head. For example, Give ...
- dock panel
http://www.cnblogs.com/masterfy/archive/2009/06/02/1494593.html http://www.cnblogs.com/wuhuacong/p/3 ...
- windows cmake安装
https://blog.csdn.net/u013832707/article/details/53127710
- Android 实现在Activity中操作刷新另外一个Activity数据列表
做android项目中遇到这样一个问题:有两个acticity,一个显示好友列表,另外一个显示会话列表,现在问题是在会话界面增加一个添加好友功能,添加好友后要求实时的刷新好友列表. 想了想,找了两种方 ...
- Java线程死锁查看分析方法
如何查看是否有Java线程死锁?下面介绍两种方法. 一.Jconsole Jconsole是JDK自带的图形化界面工具,使用JDK给我们的的工具JConsole,可以通过打开cmd然后输 ...
- Nginx学习基础(一)
Nginx是个可靠高效的中间件,就是跟其他语言连接,可以做为一个工具的服务器. 可以处理的问题: 1.反向代理 (1)正向代理(以客户端为主):访问网站的时候,早起是在做通过n多个路由访问网站的操作, ...
- Oracle学习笔记(三)
五.操作表 1.表分为行和列 约定:每行数据唯一性,每列数据同类性,每列列名唯一性. 2.数据类型 字符型 -- 固定长度的字符类型 字符类型:CHAR(n)(MAX n=2000).NCHAR(MA ...
- Oracle学习笔记(七)
九.高级查询(分组,子查询)查询升级版: 需要用到三张表员工表: desc emp EMPNO 员工号 ENAME 员工姓名 JOB 员工职位 MGR 老板员工号 HIREDATE 员工入职日期 SA ...
- windows server2012怎样关机怎样重启-详细教程
| 浏览:1991 | 更新:2014-12-15 17:33 1 2 3 4 5 6 分步阅读 百度经验:jingyan.baidu.com windows server2012和以往有些不同,关机 ...