poj1845 Sumdiv 数学题

令人痛苦van分的数学题!

题意:求a^b的所有约数(包括1和它本身)之和%9901

这怎么做呀!!!

百度:约数和定理,会发现 p1^a1 * p2^a2 * ... * pn^an
这个数的约数和是:
(1 + p1 + p1^2 + ... + p1^a1) * (1 + p2 + ... + p2^a2) * ... * (1 + pn + ... + pn^an)

证明:由乘法原理可直接证明

然后我们对于a^b运用这个公式即可。
那么对于 (1 + pi + ... + pi^ai) 我们难道要暴力求吗?
不,这显然是个等比数列!我们用公式!

那么我们就成功WA了!

…查找原因,发现q-1可能是9901的整数倍,导致无法求逆元。
那么我们退而求次,用递归求和!

a1 + a1*q + a1*q^2 + ... + a1*q^n = (q^(n/2) + 1) * (a1 + a1*q + ... + a1*q^(n/2))

把上面那个式子分n的奇偶讨论一下就行了。

(法②:当q-1为9901的整数倍时,q % 9901 = 1,又因为a1 = 1,上式显然为n + 1)

然后我们开开心心的调了一年之后WA了….
查找原因:没开long long导致qpow爆了
然后就A了!

 //poj1845 sumdiv
#include <cstdio>
using namespace std;
const int N = ,mo = ;
int p[N][],P;
int qpow(int a,int b) {
int ans=;
while(b) {
if(b&) {
ans=ans*a%mo;
}
a=a*a%mo;
b=b>>;
}
return ans;
} void split(int a,int b) {
for(int i=; a>; i++) {
if(!(a%i)) {
p[++P][] = i;
}
while(!(a%i)) {
a/=i;
p[P][]++;
}
}
for(int i=; i<=P; i++) {
p[i][]*=b;
}
return;
} long long getQsum(int a1,int q,int n) {
if(q==) {
return a1*n%mo;
}
if(n==) {
return a1;
}
if(n&) { //奇数
long long ans = ((+qpow(q,n>>))*getQsum(a1,q,n>>)+(a1*qpow(q,n-)))%mo;
return ans;
}
//偶数
long long ans = ((+qpow(q,n>>))*(getQsum(a1,q,n>>)))%mo;
return ans;
} void solve() {
long long ans=;
for(int i=; i<=P; i++) {
int temp=getQsum(,p[i][],p[i][]+);
ans*=temp;
ans%=mo;
}
printf("%I64d",ans);
return;
} int main() {
//freopen("in.in","r",stdin);
//freopen("my.out","w",stdout);
int a,b;
scanf("%d%d",&a,&b);
if(!a) {
printf("");
return ;
}
split(a,b);
solve();
return ;
}

AC代码:

我们学到了什么?

我们学到了什么?

  1. 约数和定理
  2. How to 求逆元
  3. How to 递归求等比数列和
  4. 开long long!!!!

————————end————————

poj1845 Sumdiv的更多相关文章

  1. POJ1845 Sumdiv [数论,逆元]

    题目传送门 Sumdiv Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 26041   Accepted: 6430 Des ...

  2. 【题解】POJ1845 Sumdiv(乘法逆元+约数和)

    POJ1845:http://poj.org/problem?id=1845 思路: AB可以表示成多个质数的幂相乘的形式:AB=(a1n1)*(a2n2)* ...*(amnm) 根据算数基本定理可 ...

  3. 约数之和(POJ1845 Sumdiv)

    最近应老延的要求再刷<算法进阶指南>(不得不说这本书不错)...这道题花费了较长时间~(当然也因为我太弱了)所以就写个比较易懂的题解啦~ 原题链接:POJ1845 翻译版题目(其实是AcW ...

  4. POJ1845 Sumdiv(求所有因数和+矩阵快速幂)

    题目问$A^B$的所有因数和. 根据唯一分解定理将A进行因式分解可得:A = p1^a1 * p2^a2 * p3^a3 * pn^an.A^B=p1^(a1*B)*p2^(a2*B)*...*pn^ ...

  5. poj1845 sumdiv (因数的和)

    首先分解质因数,$A^B=p_1^{m_1B}p_2^{m_2B}...p_n^{m_nB}$ 然后的话,它的所有因数的和就是$\prod{(1+p_i^1+p_i^2+...+p_i^n)}$ 用一 ...

  6. POJ1845 sumdiv 数论

    正解:小学数学数论 解题报告: 传送门! 其实不难但我数学这个方面太菜了所以还是多写点儿博客趴QAQ 然后因为是英文的所以先翻译一下,,,? 大概就是说求AB的所有约数之和,对9901取膜 这个只需要 ...

  7. POJ1845 Sumdiv 数学?逆元?

    当初写过一篇分治的 题意:求A^B的所有因子之和,并对其取模 9901再输出 对于数A=p1^c1+p2^c2+...+pn*cn,它的所有约数之和为(1+p1+p1^2+p1^3+...+p1^(c ...

  8. 题解 poj1845 Sumdiv (数论) (分治)

    传送门 大意:求A^B的所有因子之和,并对其取模 9901再输出 (这题又调了半天,把n和项数弄混了QAQ) 根据算数基本定理:A=(p1^k1)*(p2^k2)*(p3^k3)*...*(pn^kn ...

  9. noip2017考前整理(未完)

    快考试了,把我以前写过的题回顾一下.Noip2007 树网的核:floyd,推出性质,暴力.Noip2008 笨小猴:模拟Noip2008 火柴棒等式:枚举Noip2008 传纸条:棋盘dpNoip2 ...

随机推荐

  1. 使用withCount后再使用select设置查询的字段。就找不到withCount的数据了

    https://laravelacademy.org/index.php/discussion/1021 如:Article::withCount(['comments'])->select(' ...

  2. 转:Flutter Decoration背景设定(边框、圆角、阴影、形状、渐变、背景图像等)

    1 继续关系: BoxDecoration:实现边框.圆角.阴影.形状.渐变.背景图像 ShapeDecoration:实现四个边分别指定颜色和宽度.底部线.矩形边色.圆形边色.体育场(竖向椭圆).  ...

  3. restful 规范(建议)

    需求:开发cmdb,对用户进行管理. 做前后端分离,后端写api(URL),对用户表进行增删改查,应该写四个URL(还要给文档(返回值,返回,请求成功,干嘛,失败,干嘛)),然后分别写视图函数. ht ...

  4. 【git】如何去解决fatal: refusing to merge unrelated histories

    我在Github新建一个仓库,写了License,然后把本地一个写了很久仓库上传. 先pull,因为两个仓库不同,发现refusing to merge unrelated histories,无法p ...

  5. RDD

    scala> val rdd1=sc.parallelize(Array("coffe","coffe","hellp"," ...

  6. java获取本机ip(排除虚拟机等一些ip)最终解,总算找到方法了

    本文参考https://blog.csdn.net/u011809209/article/details/77236602 本文参考https://blog.csdn.net/yinshuomail/ ...

  7. Spring注解标签详解@Autowired @Qualifier等 @Slf4j

    @Slf4j @Slf4j注解实现日志输出 自己写日志的时候,肯定需要: private final Logger logger = LoggerFactory.getLogger(LoggerTes ...

  8. python数据结构与算法第十四天【二分查找】

    1.二分查找的原理 对于已经排序的列表进行最快速度的查找 2. 代码实现 (1)递归实现 def binary_search(alist, item): if len(alist) == 0: ret ...

  9. 老男孩python学习自修第二十一天【socket】

    1. 使用python编写一个静态的web服务器,能够处理静态页面的http请求 原理: a. 使用socket进行服务端和浏览器之间的通信 b. 使用多线程处理多个客户端浏览器的请求 c. 解析用户 ...

  10. 十一、ASP.NET Boilerplate

    一.ASP.NET Boilerplate 实体是 DDD(领域驱动设计)的核心概念之一.Eric Evans 是这样描述的“很多对象不是通过它们的属性定义的,而是通过一连串的连续性事件和标识定义的” ...