博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
TopCoder SRM 660 Div2 Problem 1000 Powerit (积性函数)
阅读量:4608 次
发布时间:2019-06-09

本文共 1153 字,大约阅读时间需要 3 分钟。

 

令$f(x) = x^{2^{k}-1}$,我们可以在$O(k)$的时间内求出$f(x)$。

如果对$1$到$n$都跑一遍这个求解过程,时间复杂度$O(kn)$,在规定时间内无法通过。

所以需要优化。

显然这是一个积性函数,那么实际上只要对$10^{6}$以内的质数跑$O(k)$的求解过程。

而$10^{6}$以内的质数不到$8*10^{4}$个,优化之后可以通过。

#include 
using namespace std;#define rep(i, a, b) for (int i(a); i <= (b); ++i)#define dec(i, a, b) for (int i(a); i >= (b); --i)#define MP make_pair#define fi first#define se secondtypedef long long LL;const int N = 1e6 + 10;int f[N];int c[N];int ans;int Pow(int i, int k, int m){ int p = i, q = p; rep(j, 1, k - 1){ q = 1ll * q * q % m; p = 1ll * p * q % m; } return p;}int cal(int x, int k, int m){ if (~f[x]) return f[x]; else return f[x] = Pow(x, k, m);}class Powerit { public: int calc(int n, int k, int m){ memset(f, -1, sizeof f); ans = 0; rep(i, 1, 1e6){ for (int j = i + i; j <= 1e6; j += i) c[j] = i; } ans = cal(1, k, m); rep(i, 2, n){ int x = c[i], y = i / c[i]; if (x == 1){ ans = ans + (f[i] = cal(i, k, m)); ans %= m; continue; } f[i] = 1ll * cal(x, k, m) * cal(y, k, m) % m; ans = ans + f[i]; ans %= m; } return ans; }};

  

转载于:https://www.cnblogs.com/cxhscst2/p/8449185.html

你可能感兴趣的文章
Java的内部类真的那么难以理解?
查看>>
一文搞懂Java环境,轻松实现Hello World!
查看>>
hash实现锚点平滑滚动定位
查看>>
也谈智能手机游戏开发中的分辨率自适应问题
查看>>
【转】MYSQL数据库设计规范与原则
查看>>
《中国大历史》—— 读后总结
查看>>
回溯法算法框架
查看>>
残差学习【转载】
查看>>
0302 关于IT行业的就业感想
查看>>
3、流程语句相关练习
查看>>
30、git 使用
查看>>
转发:China2008 标题:SharePoint 文档库打开HTML 直接浏览而不是打开下载对话框...
查看>>
iOS网络-02-数据解析(JSON与XML)
查看>>
python列表求和的几种等效电路
查看>>
Luogu P3393 逃离僵尸岛
查看>>
Flatten Binary Tree to Linked List
查看>>
Edit Distance
查看>>
软件工程第一次作业补充
查看>>
N76E003---输入捕获
查看>>
poj 1094 Sorting It All Out(拓扑排序)
查看>>