简单的整数分解模板

将整数分解为素因子

//将素因子全部分解出来
template<class T> void Reduce(T x,T *p,T &tot){
    tot=0;
    for(T i=2;i*i<=x;i++){
        while(x%i==0) {
            x/=i;
            p[tot++]=i;
        }
    }  if(x>1) p[tot++]=x;
}

将整数分解为幂的形式

template<class T> void Reduce(T x,T *p,T &tot){
    tot=0;
    for(T i=2;i*i<=x;i++){
        T ret=1;
        while(x%i==0) {
            x/=i;
            ret*=i;
        }
        if(ret>1) p[tot++]=ret;
    }
    if(x>1) p[tot++]=x;
}

原文地址:https://www.cnblogs.com/033000-/p/10041664.html

时间: 2024-07-29 10:15:06

简单的整数分解模板的相关文章

数论快速入门(同余、扩展欧几里德、中国剩余定理、大素数测定和整数分解、素数三种筛法、欧拉函数以及各种模板)

数学渣渣愉快的玩了一把数论,来总结一下几种常用的算法入门,不过鶸也是刚刚入门, 所以也只是粗略的记录下原理,贴下模板,以及入门题目(感受下模板怎么用的) (PS:文中蓝色字体都可以点进去查看百度原文) 附赠数论入门训练专题:点我打开专题(题目顺序基本正常,用以配套数论入门) 一.同余定理 简单粗暴的说就是:若 a-b == m 那么 a%m == b%m 这个模运算性质一眼看出...直接上入门水题: Reduced ID Numbers 附AC代码(这个也没啥模板....知道就好) #inclu

试除法整数分解 筛法整数分解 PollardRho大整数分解【模板】

试除法整数分解 int factor[11000]; //记录素因子 int ct; //记录素因子个数 void Divide(int N) { ct = 0; for(int i = 2; i <= sqrt(N*1.0); ++i) { while(N % i == 0) { factor[ct++] = i; N /= i; } } if(N != 1) factor[ct++] = N; } 筛法整数分解 const int MAXN = 11000; int Prime[MAXN],

VJ 1033 整数分解(版本2)

描述 整数分解(版本2) 一个正整数可以分解成若干个自然数之和.请你编一个程序,对于给出的一个正整数n(1<=n<=1500),求出满足要求的分解方案,并使这些自然数的乘积m达到最大. 例如n=10,则可以分解为2+2+3+3,乘积m=2*2*3*3=36 格式 输入格式 一个正整数n 输出格式 输出分解的自然数的最大乘积m 样例1 样例输入1[复制] 10 样例输出1[复制] 36 提示 简单题,所有数据随机生成 题解 : n <= 3 时, 答案最大为n,即不拆. n > 3

HDU1164_Eddy&amp;#39;s research I【Miller Rabin素数测试】【Pollar Rho整数分解】

Eddy's research I Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 6664    Accepted Submission(s): 3997 Problem Description Eddy's interest is very extensive, recently he is interested in prime

HDU1164_Eddy&#39;s research I【Miller Rabin素数测试】【Pollar Rho整数分解】

Eddy's research I Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 6664    Accepted Submission(s): 3997 Problem Description Eddy's interest is very extensive, recently he is interested in prime

Miller-Rabin 素性测试 与 Pollard Rho 大整数分解

\(\\\) Miller-Rabin 素性测试 考虑如何检验一个数字是否为素数. 经典的试除法复杂度 \(O(\sqrt N)\) 适用于询问 \(N\le 10^{16}\) 的时候. 如果我们要把询问范围加到 \(10^{18}\) ,再多组询问呢? Miller 和 Rabin 建立了Miller-Rabin 质数测试算法. \(\\\) Fermat 测试 首先我们知道费马小定理: \[ a^{p-1}\equiv 1\pmod p \] 当且仅当 \(p\) 为素数时成立. 逆命题是

[水+整数分解] poj 1365 Prime Land

题意: 给2*n个数,输入的这些数构成 sum=(a[1]^b[1])*(a[2]^b[2])... 其实就是整数分解完的数. 然后让你输出分解sum-1的结果. 从大到小. 思路: 就是输入麻烦点. 注意题目说了1的时候要输出空行. 代码: #include"cstdlib" #include"cstdio" #include"cstring" #include"cmath" #include"queue"

linux下面简单通用的Makefile模板

简单通用的Makefile模板: ############################################## # # 单目录通用Makefile # 目标文件可自己的设定 # 始须调试程序,修改 CFLAGS 变量为-Wall -g # # wuyq 20140825 ############################################## # EXECUTABLE为目标的可执行文件名, 可以根据具体的情况对其进行修改. EXECUTABLE := spi

分享一套简单的CodeSmith三层模板

Model: <%@ Template Language="C#" TargetLanguage="C#" %> <%@ Assembly Name="SchemaExplorer" %> <%@ Import Namespace="SchemaExplorer" %> <%@ Property Name="SourceTable" Type="Schem