JavaScript的大公约数/最小公约数
Greater Common Divisor/ Least Common Divisor for JavaScript
本文关键字:JavaScript 更新时间:2023-09-26
我正在试图找出计算最小公倍数(LCM)的一些问题。
为了计算GCD(两个或三个数字),我使用了两个公式:
gcdTwoNumbers:function(number1,number2){
if(number2 == 0){
return number1;
}
return this.gcdTwoNumbers(number2, number1 % number2);
}
和
gcdThreeNumbers:function(number1, number2, number3){
return this.gcdTwoNumbers(number1, this.gcdTwoNumbers(number2,number3));
}
为了计算LCM,我分别为两个或三个数字调用上述函数:
var lcm = randomNumber1 * randomNumber2 / (gcdTwoNumbers(randomNumber1,randomNumber2));
和
var lcm = randomNumber1 * randomNumber2 * randomNumber3 / (gcdThreeNumbers(randomNumber1,randomNumber2,randomNumber3));
两个数字的计算是正确的,但是三个数字的计算结果是错误的。欢迎提出任何建议或更正
问题出在LCM的计算公式上。
应该是:
var tmp = randomNumber1 * randomNumber2 / (gcdTwoNumbers(randomNumber1, randomNumber2));
var lcm = tmp*randomNumber3 / gcdTwoNumbers(tmp,randomNumber3);
所以,gcdThreeNumbers函数是无用的
相关文章:
- 为什么不't Javascript对我的输入值进行了一些重新检查
- 创建一个类似链接的按钮,并通过Javascript函数打开一个新的弹出窗口
- 将函数的上下文应用于javascript变量
- 使用php或javascript从facebook相册URL中删除多余的部分
- 正在添加'X'按钮,在文本字段旁边使用javascript
- 如何在JavaScript中将字符串转换为函数引用
- 模糊事件的Javascript测试
- Javascript更改图标
- 如何将HTML id分配给元素,以及如何将JavaScript应用于元素
- 如何使用WCF服务和javascript表单post上传.doc文件
- javascript结合了数组和字典
- 这是什么 ==- javascript 运算符
- 从javascript创建一个列表
- 无法在通过jQuery的ajax加载的页面中执行javascript
- Javascript:selenium Web驱动程序isDisplayed()不工作
- 如何通过ajax刷新JSF填充的javascript变量
- 如何在Javascript中将JSon对象转换为数组
- Javascript生成的表单未提交
- 使用javascript将动态表从一个html页面打印到另一个html页
- 通过javascript重定向html传递php变量