正题

题目链接:https://loj.ac/p/6247


题目大意

给出\(n,k\)求

\[\sum_{0\leq i\leq n,i|k}\binom{n}{i}
\]

对\(998244353\)取模

\(1\leq n\leq 10^{15},1\leq k\leq 2^{20},k=2^p(p\in N)\)


解题思路

随便找的一题竟然是单位根反演,不过很基础而且很裸。

首先单位根反演的式子\([i|k]=\frac{1}{k}\sum_{j=0}^{k-1}\omega_k^{i\times j}\)

然后带到这题的式子就是

\[\sum_{i=0}^n\frac{1}{k}\sum_{j=0}^{k-1}\omega_k^{i\times j}\binom{n}{i}
\]

然后把\(j\)提出来

\[\frac{1}{k}\sum_{j=0}^{k-1}\sum_{i=0}^n(\omega_k^{i})^j\binom{n}{i}
\]

然后二项式定理

\[\frac{1}{k}\sum_{j=0}^{k-1}(\omega_k^{i}+1)^n
\]

额但是\(n\)很大直接用复数精度肯定会炸,但是\(998244353-1=2^{23}\times 7\times 17\)...又因为\(k=2^p\),其实就是类似于\(NTT\)的思路我们直接用原根\(\omega_k^1=g^{\frac{P-1}{k}}\)就好了。

时间复杂度\(O(k\log n)\)


code

#include<cstdio>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std;
const ll P=998244353;
ll n,k,ans;
ll power(ll x,ll b){
ll ans=1;
while(b){
if(b&1)ans=ans*x%P;
x=x*x%P;b>>=1;
}
return ans;
}
signed main()
{
scanf("%lld%lld",&n,&k);
ll g=power(3,(P-1)/k),z=1;
for(ll i=0;i<k;i++,z=z*g%P)
(ans+=power(z+1,n)%P)%=P;
printf("%lld\n",ans*power(k,P-2)%P);
return 0;
}

最新文章

  1. 【译】用jQuery 处理XML--浏览器中的XML与JavaScript
  2. 【noiOJ】p1776
  3. Winform 窗体最小化隐藏在桌面右下角:转
  4. HDU 4718 The LCIS on the Tree(树链剖分)
  5. easyui combobox 智能提示搜索
  6. JAXB - XML Schema Types, Defining Subtypes
  7. CSS实现table td中文字的省略与显示
  8. 推荐一款JSON字符串查看器
  9. Python学习笔记(二)Python的数据类型和变量
  10. html怎么引用css
  11. The 2nd tip of DB Query Analyzer
  12. 最短路问题之Dijkstra算法
  13. 三星5.0以上设备最完美激活XPOSED框架的经验
  14. 使用Linux命令行测试网速
  15. kubernetes学习笔记之十三:基于calico的网络策略入门
  16. sparse 稀疏函数的用法2
  17. Python3.5 学习十九 Django分模块讲解 MTV+URL
  18. LUN
  19. jdk 下载地址 服务器
  20. 恒大威武!关于SQL的一些基础知识整理回顾

热门文章

  1. [ES6深度解析]15:模块 Module
  2. redisson 分布式加锁
  3. wpf 中 theme 的使用 和 listview 模板的使用.
  4. dataTemplate 的使用之listView
  5. C# 排序列表(SortedList)
  6. opencv入门系列教学(二)图像入门:读取、展示并保存视频
  7. rtvue-lowcode:一款基于uniapp框架和uview组件库的开源低代码开发平台
  8. reids在linux上的安装《四》
  9. Oracle环境配置之山路十八弯
  10. 并发编程之:AQS源码解析