`
mybwu_com
  • 浏览: 192667 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

算法练习--整数拆分为素数乘积

 
阅读更多

问题:

输入6

输出 1*2*3


1. build素数表

2. 从素数表按次序取素数,n除素数,如果不能整除,素数表索引++,否则,n/=素数,继续判断

3. 遍历素数表

4. 有限性:素数表需要足够大 ,如果数字非常大,此算法需要改变


JS 实现:


function p(n){
if(n<2) {return 0;}
if(n == 2){return 1;}
for(var i = 2; i < n; i++){
if(n%i == 0){return 0;}
}
return 1;
}

var pl = new Array();
for(var i = 2,index = 0;index<100;i++){
if(p(i) == 1){pl.push(i);index++;}
}

function f(n){
var pIndex = 0;
var ret = "1";

for(;pIndex<100; ){
if( n % pl[pIndex] == 0){
ret += "*" + pl[pIndex]; 
n/=pl[pIndex];
}
else{
if(p(n)){
ret += "*" + n;
return ret;
}
pIndex ++;
}

}

return ret;
}

console.log(f(111223));





分享到:
评论

相关推荐

    算法-数论- 整数分解.rar

    这个主题通常涉及到将一个大整数表示为两个或多个较小整数的乘积,比如找到两个质数p和q使得n=p*q。这种分解过程在诸如RSA公钥加密算法中起着至关重要的作用。 在数论中,整数分解问题的难度是众所周知的。对于...

    java实现RSA算法的大整数编程----实现对某个整数的加解密

    1. 选择两个大素数p和q,计算它们的乘积n=p*q。 2. 计算欧拉函数φ(n)=(p-1)*(q-1)。 3. 选择一个整数e,1φ(n),且e与φ(n)互质。e通常选择为65537,因为这是常用的高效值。 4. 计算e关于φ(n)的模逆d,即存在一个...

    acm主要算法---acm主要算法

    - **基本思想**:将一个正整数分解为多个质数的乘积。 - **应用**:密码学、加密算法等领域。 以上就是ACM竞赛中常用的主要算法及其相关内容的详细介绍。这些算法不仅能够帮助选手在比赛中取得好成绩,同时也是...

    java算法练习题 大家下载看看啦

    ### Java算法练习题知识点解析 #### 1. 斐波那契数列 - **描述**:编写一个程序,计算斐波那契数列的前N项。 - **实现思路**: - 使用循环结构(如`for`循环)来依次计算每一项的值。 - 设置两个变量分别存储...

    RSA加密解密算法objective-c 完美实现

    - 首先,随机选择两个大素数p和q,它们的乘积n=p*q。 - 计算φ(n)=(p-1)*(q-1),这是欧拉函数,它定义了小于n且与n互质的正整数的数量。 - 接着,选择一个与φ(n)互质的整数e,通常e取为65537,这是个常用的、...

    算法-大整数的因子(信息学奥赛一本通-T1171)(包含源程序).rar

    标题中的“大整数的因子”是指在计算机科学和算法设计中处理的一种特定问题,它涉及到寻找一个大整数的所有正除数。这个问题通常出现在信息学竞赛和算法竞赛中,如描述中提到的“信息学奥赛一本通-T1171”。这类问题...

    Pohlig-Hellman算法

    Pohlig-Hellman算法是一种用于解决有限域上离散对数问题的有效方法,尤其在大质数的乘法群中,当群的阶可以分解为较小素数的幂时,该算法能显著提高计算效率。本文将详细解析Pohlig-Hellman算法的工作原理、关键步骤...

    VB程序设计常用算法

    - 质因数分解:分解一个大整数为质数的乘积,如Pollard's rho算法。 6. 图论算法: - 深度优先搜索(DFS)和广度优先搜索(BFS):遍历图中的节点和边,用于拓扑排序、找出连通分量等。 - 最小生成树:Prim's...

    素数判定MillerRabin算法

    它们是构建所有正整数的基础,因为任何大于1的整数都可以表示为素数的乘积。例如,6=2×3,9=3×3。 **2. 强素数测试与随机性** Miller-Rabin素数测试是一种基于概率的强素数测试方法,它利用了费马小定理和二次...

    guss--primes.zip_素数的判断Java

    通过这个"猜素数"的程序,你可以实践如何在Java中创建一个实用的小工具,同时加深对素数和算法的理解。在实际编程项目中,类似的逻辑可以被用于优化更复杂的计算,例如在大型数据集上寻找素数或者构建更复杂的加密...

    算法-数论- 概述.rar

    1. 素性测试:如Miller-Rabin素性测试和AKS素性测试,是判断大整数是否为质数的快速方法,对密码学和算法设计至关重要。 2. 费马小定理与欧拉定理:它们提供了一种检查整数是否满足模幂运算性质的方法,常用于快速...

    算法-leetcode-剑指offer上的题很多

    - **乘积最大子数组(Product of Array Exclude Itself)**: 乘积最大连续子序列的乘积。 - **数组中的第一个不重复的数字(First Missing Positive)**: 找出数组中缺失的第一个正数。 #### 排序算法 - **合并排序数组...

    慎用中国剩余定理提高RSA算法效率-孙宇.pdf

    因此,大整数的因式分解是RSA算法安全性的核心问题。 为了在RSA加密过程中提高效率,经常使用一种数学定理——中国剩余定理(Chinese Remainder Theorem,简称CRT)。中国剩余定理是数论中的一个重要定理,它提供了...

    算法-数论- 莫比乌斯反演.rar

    2. 如果n是质数幂的乘积,即n=p^k(其中p是质数,k是非负整数),则μ(n) = (-1)^k。 3. 对于其他非质数幂的合数n,μ(n) = -μ(d),其中d是n的任意一个真因子。 莫比乌斯函数的关键性质包括: - 反对称性:μ(ab)...

    100个经典C语言算法

    - **算法描述**:对于给定的正整数n,从最小的质数2开始尝试除法,直至n本身。 - **编程实现**: - 使用`for`循环从2开始递增地检查每一个可能的质数。 - 在循环内部使用`while`循环不断除以该质数直到不能再整除...

    java经典算法 java经典算法

    程序4通过循环从最小的质数2开始,不断尝试对输入的正整数n进行除法,直到n不能被当前质数k整除,再将k加1,继续检查,直到n变为1,表示质因数分解完成。 这些经典的Java算法示例展示了基础的数学逻辑和编程技巧,...

    C语言中的 RSA加密和解密算法-_RSA加解密算法的演示,C语言实现

    RSA算法是一种非对称加密算法,它在信息安全领域有着广泛的应用,特别是在数据传输的安全性上。C语言作为底层编程语言,常被用来实现各种复杂的算法,包括RSA。本篇文章将详细探讨C语言中RSA加解密算法的实现,并...

    用大数库Miracl实现的RSA

    在RSA加解密过程中,首先选择两个大素数p和q,计算它们的乘积n=p*q,然后计算欧拉函数φ(n)=(p-1)*(q-1)。接下来,选取一个与φ(n)互质的整数e作为公钥的指数,再找到e关于φ(n)的模逆元d作为私钥的指数。这样,公钥...

    RSA算法在C语言中的实现

    该算法基于大数因子分解的困难性,即找到两个大质数的乘积很容易,但要从这个乘积中恢复出原来的质数则非常困难。这种特性使得RSA在信息安全领域有着广泛的应用,如数字签名、数据加密等。 在C语言中实现RSA算法,...

    java算法练习题 初学者

    【Java算法练习题初学者】 对于Java初学者来说,掌握基础的算法是非常重要的,这有助于提升编程思维和问题解决能力。下面将详细讲解几个经典的Java算法练习题。 1. **兔子问题**(斐波那契数列): 这是一个经典...

Global site tag (gtag.js) - Google Analytics