数论 --- 费马小定理 + 快速幂 HDU 4704 Sum
来源:互联网 发布:日本神户制钢造假知乎 编辑:程序博客网 时间:2024/06/06 02:23
Sum Problem's Link: http://acm.hdu.edu.cn/showproblem.php?pid=4704
View Code
Problem's Link: http://acm.hdu.edu.cn/showproblem.php?pid=4704
Mean:
给定一个大整数N,求1到N中每个数的因式分解个数的总和。
analyse:
N可达10^100000,只能用数学方法来做。
首先想到的是找规律。通过枚举小数据来找规律,发现其实answer=pow(2,n-1);
分析到这问题就简单了。由于n非常大,所以这里要用到费马小定理:a^n ≡ a^(n%(m-1)) * a^(m-1)≡ a^(n%(m-1)) (mod m) 来优化一下,不然直接用快速幂会爆。
Time complexity: O(n)
Source code:
/** this code is made by crazyacking* Verdict: Accepted* Submission Date: 2015-05-22-21.21* Time: 0MS* Memory: 137KB*/#include <queue>#include <cstdio>#include <set>#include <string>#include <stack>#include <cmath>#include <climits>#include <map>#include <cstdlib>#include <iostream>#include <vector>#include <algorithm>#include <cstring>#define LL long long#define ULL unsigned long longusing namespace std;const int mod=1e9+7;const int MAXN=100010;char s[MAXN];long long quickPower(long long a,long long b,long long m){ long long ans=1; while(b) { if(b&1) ans=(ans*a)%m,b--; b/=2,a=a*a%m; } return ans;}int main(){ ios_base::sync_with_stdio(false); cin.tie(0); while(~scanf("%s",s)) { ULL n=0; for(int i=0;s[i];++i) n=(n*10+s[i]-'0')%(mod-1); printf("%d\n",(int)quickPower(2,((n-1)%(mod-1))%mod,mod)); } return 0;}/**/
0 0
- 数论 --- 费马小定理 + 快速幂 HDU 4704 Sum
- [数论]HDU 4704 Sum 费马小定理
- HDU 4704 Sum 费马小定理+快速幂
- HDU 4704Sum(费马小定理+快速幂)
- HDU 4704 Sum(快速幂+费马小定理)
- hdu 4704 Sum (费马小定理+快速幂)
- HDU--4704 Sum【费马小定理,快速幂】
- 数论+快速幂-hdu-4704-Sum
- HDU - 4704 Sum (费马小定理 + 快速幂)
- hdu 4704 sum(费马小定理+快速幂)
- [HDU 4704] Sum · 费马小定理 & 快速幂
- HDU 4704 SUM 整数快速幂+费马小定理
- HDU 4704 Sum(费马小定理,组合数学,快速幂)
- HDU 4704 Sum 【隔板原理+费马小定理+快速幂】
- HDOJ Sum 4704【费马小定理+快速幂】
- hdoj 4704 Sum 【费马小定理 + 快速幂】
- HDU 4704 Sum (费马定理+快速幂)
- hdu 4704 Sum (整数和分解+快速幂+费马小定理降幂)
- JAVA
- 概率论 --- Uva 11181 Probability|Given
- Linux
- Activity从Service回调数据
- 组合数(Lucas定理) + 快速幂 --- HDU 5226 Tom and matrix
- 数论 --- 费马小定理 + 快速幂 HDU 4704 Sum
- 2015百度之星 大搬家
- 2015百度之星 列变位法解密
- 2015百度之星 IP聚合
- HBase应用程序开发03查询
- 2015百度之星 放盘子
- 2015百度之星 下棋
- 2015百度之星 单调区间
- 线段树 + 矩阵 --- ZOJ 3772 Calculate the Function