博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
紫书 例题 10-3 UVa 10375 (唯一分解定理)
阅读量:7002 次
发布时间:2019-06-27

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

这道题感觉非常的秀

因为结果会很大,所以就质因数分解分开来算

非常的巧妙!

#include
#include
#include
#include
#define REP(i, a, b) for(int i = (a); i < (b); i++)using namespace std;const int MAXN = 11234;bool is_prime[MAXN];vector
prime;int e[MAXN];void init() //初始化质数 { memset(is_prime, true, sizeof(is_prime)); is_prime[0] = is_prime[1] = false; REP(i, 2, MAXN) { if(is_prime[i]) prime.push_back(i); REP(j, 0, prime.size()) { if(i * prime[j] > MAXN) break; is_prime[i * prime[j]] = false; if(i % prime[j] == 0) break; } }}void add_integer(int n, int d) //表示把n的d次方质因数分解,结果存到数组e里面 { //例如d = 1表示乘以n,d = -1表示除以n REP(i, 0, prime.size()) //需要预处理好素数 { while(n % prime[i] == 0) //注意这里是while { n /= prime[i]; e[i] += d; //e[i]表示第i个素数的幂 } if(n == 1) break; //节省时间 }}void add(int n, int d) { REP(i, 2, n + 1) add_integer(i, d); }int main(){ init(); int p, q, r, s; while(~scanf("%d%d%d%d", &p, &q, &r, &s)) { memset(e, 0, sizeof(e)); add(p, 1); add(q, -1); add(p-q, -1); add(r, -1); add(s, 1); add(r-s, 1); double ans = 1; REP(i, 0, prime.size()) ans *= pow(prime[i], e[i]); printf("%.5lf\n", ans); } return 0;}

转载于:https://www.cnblogs.com/sugewud/p/9819516.html

你可能感兴趣的文章
CSS效果集锦(持续更新中)
查看>>
通过重建Hosting系统理解HTTP请求在ASP.NET Core管道中的处理流程[中]:管道如何处理请求...
查看>>
Eigen教程(9)
查看>>
单元测试
查看>>
操作hadoop的经验积累
查看>>
微信企业号验证
查看>>
请问set JAVA_OPTS的各项參数是什么意思?
查看>>
Linux安装JDK
查看>>
C#常用控件缩写
查看>>
.NET足球赛事资料数据库平台SmartLottery开源发布——全球足球联赛应有尽有
查看>>
关于Eclipse生成和导入Patch文件.
查看>>
如何使用Photoshop(PS)将图片的底色变为透明
查看>>
IDEA实现序列号接口
查看>>
人件札记:保持高效的办公室环境
查看>>
Mysql中使用流式查询避免数据量过大导致OOM
查看>>
为什么中台是传统企业数字化转型的关键?
查看>>
中国技术开放日专场在美国旧金山隆重开幕
查看>>
从责任界定和问题预警角度 解读全栈溯源对DevOps的价值
查看>>
百度发布开源智能边缘计算平台OpenEdge
查看>>
JavaScript引擎V8 5.1遵循了更多的ECMAScript规范并支持WASM
查看>>