摘要:质数的定义质数又称素数。一个大于的自然数,除了和它自身外,不能整除其他自然数的数叫做质数否则称为合数。实现思路循环所有可能的备选数字,然后和中间数以下且大于等于的整数进行整除比较,如果能够被整数,则肯定不是质数,相反,就是质数。
质数的定义
质数又称素数。一个大于1的自然数,除了1和它自身外,不能整除其他自然数的数叫做质数;否则称为合数。实现思路
循环所有可能的备选数字,然后和中间数以下且大于等于2的整数进行整除比较,如果能够被整数,则肯定不是质数,相反,就是质数。
第一种算法这也是最可能先想到的,也就是直接和备选数的中间数去比较,算法源码如下:
/** * 获取所有的质数 * @param array $arr * @return array */ function get_prime_number($arr = []) { // 质数数组 $primeArr = []; // 循环所有备选数 foreach ($arr as $value) { // 备选数和备选数的中间数以下的数字整除比较 for ($i = 2; $i <= floor($value / 2); $i++) { // 能够整除,则不是质数,退出循环 if ($value % $i == 0) { break; } } // 被除数$j比备选数的中间数大的则为质数 // 这样判断的依据: // 假如备选数为质数,则内层的for循环不会break退出,则执行完毕,$i会继续+1,即最后$i = floor($value / 2) + 1 // 假如备选数不为质数,则内层的for循环遇到整除就会break退出,$i不会继续+1,即最后$i <= floor($value / 2) if ($value != 1 && $i > floor($value / 2)) { $primeArr[] = $value; } } return $primeArr; }
### 第二种算法
认真的来说的话,这也不算是另外一种算法,只是对于第一种的稍微点点优化,及中间最大数的优化,缩小比较范围,算法源码如下:
/** * 获取所有的质数 * @param array $arr * @return array */ function get_prime_number($arr = []) { // 质数数组 $primeArr = []; // 循环所有备选数 foreach ($arr as $value) { // 备选数和备选数的中间数以下的数字整除比较 for ($i = 2; $i <= floor($value / $i); $i++) { // 能够整除,则不是质数,退出循环 if ($value % $i == 0) { break; } } // 被除数$j比备选数的中间数大的则为质数 // 这样判断的依据: // 假如备选数为质数,则内层的for循环不会break退出,则执行完毕,$i会继续+1,即最后$i = floor($value / $i) + 1 // 假如备选数不为质数,则内层的for循环遇到整除就会break退出且$i不会继续+1,即最后$i <= floor($value / $i) if ($value != 1 && $i > floor($value / $i)) { $primeArr[] = $value; } } return $primeArr; }第三种算法
这个的话也是对于第二种的优化,即,直接从完整数组中删除所有不是质数的数即可,算法源码如下:
/** * 获取所有的质数 * @param array $arr * @return array */ function get_prime_number_three($arr = []) { // 质数数组 $primeArr = $arr; // 循环所有备选数 foreach ($primeArr as $key => $value) { if ($value == 1) { unset($primeArr[$key]); continue; } // 备选数和备选数的中间数以下的数字整除比较 for ($i = 2; $i <= floor($value / $i); $i++) { // 能够整除,则不是质数,从数组中删除且退出循环 if ($value % $i == 0) { unset($primeArr[$key]); break; } } } // 重置数组索引返回 return array_values($primeArr); }使用方法
比如,求1-100的所有质数
// 所有备选数数组 $numberArr = range(1, 100, 1); // 获取备选数中的所有质数 $primeNumberArr = get_prime_number($numberArr); // 输出打印 print_r($primeNumberArr);
又比如,求指定数组中的所有质数
// 所有备选数数组 $numberArr = [11, 22, 33, 66, 77, 3, 8, 10, 99]; // 获取备选数中的所有质数 $primeNumberArr = get_prime_number($numberArr); // 输出打印 print_r($primeNumberArr);最后
如有说的不对的地方,请大家多多谅解,欢迎留言和我沟通、交流,谢谢!
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/30896.html
摘要:算法公钥加密算法是年由罗纳德李维斯特阿迪萨莫尔和伦纳德阿德曼一起提出的。是目前最有影响力的公钥加密算法,它能够抵抗到目前为止已知的绝大多数密码攻击,已被推荐为公钥数据加密标准。 上篇文章介绍了对称加密的原理,但是它的最大问题就是加密和解密的密钥是相同的,并且不能保证密钥能安全的送到双方手里,即使安全的送到双方手里,免不了内部会有卧底的存在 非对称加密 既然有对称加密,那么自然会联想到非...
摘要:首先明确一下概念质数又称素数,有无限个。质数定义为在大于的自然数中,除了和它本身以外不再有其他因数的数称为质数。以内质数表质数的个数是无穷的。 首先声明本人水平有限,仅仅做一下记录,有错的地方请指正,文章垃圾请包容!! 在网上不小心浏览到一篇技术博客,叫做《求质数算法的N种境界(N>10)》,写得很好,有兴趣的读者自己去搜索。然后就想自己去试试这篇博客里写得各种求质数的方法。 不想搭...
摘要:认真做题的分割线第一题乘积最大子序列难度中等给定一个整数数组,找出一个序列中乘积最大的连续子序列该序列至少包含一个数。 写在前面的话 慢慢转变思路,不再死磕不会做的题,思路可以先借鉴,但是一定要吃透透。上周末看完看完了《算法图解》,感觉对一些题目的思路有比较大的帮助,但是还是要在实践中理解。 认真做题的分割线 第一题 152. 乘积最大子序列难度:中等给定一个整数数组nums,找出一个...
摘要:算法的确有他独特的魅力。然后我在做这个题的时候,其实也用到了类似质因数分解,只是其实我们可以更好的利用到因数这一个特性。判断一个数是否是质数质数列表一开始我们认为每一个数都可能是自身的幂线性筛为质数遍历质数列表为质数的幂 前言 从三月份到现在,大大小小笔试了十几家公司(主要是因为一直solo code,没人内推),然后也能感觉到自己的进步把。从编程题只能ac一题到后来的ak。今天面腾讯...
摘要:背景不对称加密算法可是算是世界上最重要的加密算法,其中包括我们熟悉的的加密。现在我们分步来看,这个全球最重要的加密算法,都需要哪些数学知识。我们常说的算法中的多少位,就是用二进制表示后的位数,在我们例子就是位。其中表示两个数的最大公约数。 背景 RSA不对称加密算法可是算是世界上最重要的加密算法,其中包括我们熟悉的https的加密。为了完全弄明白他的实现原理,我们需要对数论这门学科,有...
阅读 948·2021-11-23 09:51
阅读 2657·2021-08-23 09:44
阅读 610·2019-08-30 15:54
阅读 1390·2019-08-30 13:53
阅读 3073·2019-08-29 16:54
阅读 2485·2019-08-29 16:26
阅读 1138·2019-08-29 13:04
阅读 2239·2019-08-26 13:50