不同语言实现质因数分解算法的差异
liebian365 2024-11-17 13:14 11 浏览 0 评论
关于质因数分解算法用不同语言的实现方法
任一一个偶数可以分解为多个质数相乘,例如:
20 = 2 * 2 * 5
100 = 2 * 2 * 5 * 5
55 = 5 * 11
60 = 2 * 2 * 3 * 5
按数学运算:列竖式,拿最小的素数做除数,不断整除得到新的得数,最后把所有的除数和最后的得数连起来就是。
- 则先从最小的素数2开始整除
- 当能够整除该素数时,将数字赋值为整除后的得数
- 继续从2开始整除
- 如果2无法整除,则逐个递加到新的素数作为除数
- 最后能整除的素数与最后的得数就是结果
1. 先设立一个除数,从最小的质数开始,也就是2;
2. 当能够被当前除数整除时,该除数就是因数,将原数字设为被整除后的结果;
3. 继续从该除数开始整除新的结果,并不断循环;
4. 当无法被整除时,则递增除数,得到新的除数,继续第2步;
5. 直到除数的平方大于要分解的值,终止循环。
最后所有可整除的除数与最后的大于1的余数就是结果。
不同语言的特点
C语言代码实现如下,该*factorize可以返回一个分解后的数组。从代码里可以看出,首先需要申请一个动态数组*result,长度为len的内存空间。该数组用来保存分解数,每分解出一个数字时则追加到数组中去,数组下标也随之增加。当分解完成后,最后返回分解数的数组。
代码逻辑:
1. 双循环,自2开始遍历。
2. 外循环为继续分解的判断条件,当某个数的乘方大于要分解的数字时,就终止循环不再分解。如果当前数字无法分解,则加1继续分解。
3. 内循环则不断用被分解的数字来除以约数,能除尽则将被分解数赋值为得数,并继续除以约数来分解,当该数字无法作为约数整除时,则跳出循环。
4. 当全部分解后,有的情况下原数字刚好被除尽,有些情况无法除尽,得数大于1,此时该得数就是最后的分解数。
C++代码实现与C语言一致,因为没有用到面向对象,所以没有任何区别。
Java版使用了ArrayList,是长度可变的列表,相比C语言使用数组来讲要方便些。代码上基本一样,如果也使用int数组,那代码就一模一样了。
JavaScript语言的数组没有类型,也无需指定长度,使用起来非常简单易懂。整个代码写法与Java版本如出一辙。
Typescript是JS的一个变种或者称之为超集,完全兼容JS语言,最后会编译成JS来执行。主要是基于类和强类型,写法上与JS几无差异。当然也可以不按类的方式来写。
Python是面向对象语言,与Java不同,方法也可以脱离于类存在。看Python代码,可以说是最简单明了的,可以说最易懂。与JS一样,Python也是动态脚本语言,数组也是动态可变的,非常好用。其实Python与JS也很像,只是相比JS来讲,是强类型的(当然也不是严格意义的强类型,这点与TS很像)。
Go语言与C类似,不以类为基础,其语言简练,语法上是C和JS的混合体,变量声明也是var。数组空间也需要提前申请。无需括号和分号,相对比较简洁。从这段代码来看与C差异不大,本质上是C的变体。
Kolin是Java的一种语法糖,是完全兼容Java语法的,最后也会变成class来执行。在Kotlin 中没有原始类型,一切都是对象。参数参数一旦将值分配给val,就无法更改。如果想重新分配它,则必须将其声明为var,而在Kotlin的方法中,参数隐式声明为final val,也无法更改参数。因此,这里将number赋值给变量num。
Dart是支持即时编译和提前编译的语言,语法与JS基本上一致,只不过需要提前编译并且严格类型。但在实际使用上与JS可谓非常接近,熟悉JS或TS的开发者上手几乎零成本。这里取整除法与其他语言略有不同,如果不加~则得到小数了。
Swift是苹果推出的旨在替代Objective-C进行苹果App开发的语言。从语法外形上跟JS非常像,var声明,function为第一型,与Go也很类似,还不要分号,function缩写为func。Swift数组声明非常简单,无需指定长度,不断append即可。
OC是苹果原生的开发语言,来自于C语言,就像windows里面的VC++一样。但说实话OC的语法看起来不是很友好,从变量声明到对象调用,看起来与其他语言不是很一致,但总体上来也是类C的,所以本质上还是一样。数组要申请分配空间,长度无需指定。数组操作和对象引用的写法上与其他差异较大,但总体结构差异不大。
从以上的代码可以看出,它们长得都很像,因为都是类C的语言(Python稍有不同,无花括号,缩进语句)。其中Python与JS最为简洁清晰、易懂,因此非常受追捧。从语言趋势上看,几乎所有最新的语言都在学习JS的优点,当然都摒弃了JS弱类型的特点。新的语言像Swift和Go、Dart、TS、Kotlin等都借鉴了它的特点,基本上来新语言就是C+Java+JS的结合体。
今天介绍的这几门语言是未来编程语言的趋势。它们之间的外形差异越来越小,对于数据结构、作用域、语法等都大同小异,掌握一门后再学习其他的会变得很容易。
完整代码地址:
https://github.com/microwind/algorithms/tree/master/factor
相关推荐
- 快递查询教程,批量查询物流,一键管理快递
-
作为商家,每天需要查询许许多多的快递单号,面对不同的快递公司,有没有简单一点的物流查询方法呢?小编的回答当然是有的,下面随小编一起来试试这个新技巧。需要哪些工具?安装一个快递批量查询高手快递单号怎么快...
- 一键自动查询所有快递的物流信息 支持圆通、韵达等多家快递
-
对于各位商家来说拥有一个好的快递软件,能够有效的提高自己的工作效率,在管理快递单号的时候都需要对单号进行表格整理,那怎么样能够快速的查询所有单号信息,并自动生成表格呢?1、其实方法很简单,我们不需要一...
- 快递查询单号查询,怎么查物流到哪了
-
输入单号怎么查快递到哪里去了呢?今天小编给大家分享一个新的技巧,它支持多家快递,一次能查询多个单号物流,还可对查询到的物流进行分析、筛选以及导出,下面一起来试试。需要哪些工具?安装一个快递批量查询高手...
- 3分钟查询物流,教你一键批量查询全部物流信息
-
很多朋友在问,如何在短时间内把单号的物流信息查询出来,查询完成后筛选已签收件、筛选未签收件,今天小编就分享一款物流查询神器,感兴趣的朋友接着往下看。第一步,运行【快递批量查询高手】在主界面中点击【添...
- 快递单号查询,一次性查询全部物流信息
-
现在各种快递的查询方式,各有各的好,各有各的劣,总的来说,还是有比较方便的。今天小编就给大家分享一个新的技巧,支持多家快递,一次能查询多个单号的物流,还能对查询到的物流进行分析、筛选以及导出,下面一起...
- 快递查询工具,批量查询多个快递快递单号的物流状态、签收时间
-
最近有朋友在问,怎么快速查询单号的物流信息呢?除了官网,还有没有更简单的方法呢?小编的回答当然是有的,下面一起来看看。需要哪些工具?安装一个快递批量查询高手多个京东的快递单号怎么快速查询?进入快递批量...
- 快递查询软件,自动识别查询快递单号查询方法
-
当你拥有多个快递单号的时候,该如何快速查询物流信息?比如单号没有快递公司时,又该如何自动识别再去查询呢?不知道如何操作的宝贝们,下面随小编一起来试试。需要哪些工具?安装一个快递批量查询高手快递单号若干...
- 教你怎样查询快递查询单号并保存物流信息
-
商家发货,快递揽收后,一般会直接手动复制到官网上一个个查询物流,那么久而久之,就会觉得查询变得特别繁琐,今天小编给大家分享一个新的技巧,下面一起来试试。教程之前,我们来预览一下用快递批量查询高手...
- 简单几步骤查询所有快递物流信息
-
在高峰期订单量大的时候,可能需要一双手当十双手去查询快递物流,但是由于逐一去查询,效率极低,追踪困难。那么今天小编给大家分享一个新的技巧,一次能查询多个快递单号的物流,下面一起来学习一下,希望能给大家...
- 物流单号查询,如何查询快递信息,按最后更新时间搜索需要的单号
-
最近有很多朋友在问,如何通过快递单号查询物流信息,并按最后更新时间搜索出需要的单号呢?下面随小编一起来试试吧。需要哪些工具?安装一个快递批量查询高手快递单号若干怎么快速查询?运行【快递批量查询高手】...
- 连续保存新单号功能解析,导入单号查询并自动识别批量查快递信息
-
快递查询已经成为我们日常生活中不可或缺的一部分。然而,面对海量的快递单号,如何高效、准确地查询每一个快递的物流信息,成为了许多人头疼的问题。幸运的是,随着科技的进步,一款名为“快递批量查询高手”的软件...
- 快递查询教程,快递单号查询,筛选更新量为1的单号
-
最近有很多朋友在问,怎么快速查询快递单号的物流,并筛选出更新量为1的单号呢?今天小编给大家分享一个新方法,一起来试试吧。需要哪些工具?安装一个快递批量查询高手多个快递单号怎么快速查询?运行【快递批量查...
- 掌握批量查询快递动态的技巧,一键查找无信息记录的两种方法解析
-
在快节奏的商业环境中,高效的物流查询是确保业务顺畅运行的关键。作为快递查询达人,我深知时间的宝贵,因此,今天我将向大家介绍一款强大的工具——快递批量查询高手软件。这款软件能够帮助你批量查询快递动态,一...
- 从复杂到简单的单号查询,一键清除单号中的符号并批量查快递信息
-
在繁忙的商务与日常生活中,快递查询已成为不可或缺的一环。然而,面对海量的单号,逐一查询不仅耗时费力,还容易出错。现在,有了快递批量查询高手软件,一切变得简单明了。只需一键,即可搞定单号查询,一键处理单...
- 物流单号查询,在哪里查询快递
-
如果在快递单号多的情况,你还在一个个复制粘贴到官网上手动查询,是一件非常麻烦的事情。于是乎今天小编给大家分享一个新的技巧,下面一起来试试。需要哪些工具?安装一个快递批量查询高手快递单号怎么快速查询?...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- wireshark怎么抓包 (75)
- qt sleep (64)
- cs1.6指令代码大全 (55)
- factory-method (60)
- sqlite3_bind_blob (52)
- hibernate update (63)
- c++ base64 (70)
- nc 命令 (52)
- wm_close (51)
- epollin (51)
- sqlca.sqlcode (57)
- lua ipairs (60)
- tv_usec (64)
- 命令行进入文件夹 (53)
- postgresql array (57)
- statfs函数 (57)
- .project文件 (54)
- lua require (56)
- for_each (67)
- c#工厂模式 (57)
- wxsqlite3 (66)
- dmesg -c (58)
- fopen参数 (53)
- tar -zxvf -c (55)
- 速递查询 (52)