如何求两个数的所有公约数

如何求两个数的所有公约数
数学人气:479 ℃时间:2020-02-05 06:26:06
优质解答
把两个数分别写成质数相乘的形式,比如求24和36的公约数,24=2×2×2×3,
36=2×2×3×3,
则重复的三个数(2,2,3)从其中挑选的任意数量的数字相乘的结果都是他们的公约数.有2,3,4,6,12.我想把它编写成一个程序,能够循环计算的,就像求两个数的最大公约数那样能够依次用大数除以小数那种类似的方法。
适合于任意数的算法,不想用穷举法来算,不好编程啊
能帮我想到吗???那只能先用你上面的辗转相除法求出最大公约数,然后对最大公约数与小于等于他一半大小的数相除,能整除的数还有商都是它的约数。(所有的公约数都在最大公约数之中)真是太感谢了,所有公约数果然在最大公约数中。
我来回答
类似推荐
请使用1024x768 IE6.0或更高版本浏览器浏览本站点,以保证最佳阅读效果。本页提供作业小助手,一起搜作业以及作业好帮手最新版!
版权所有 CopyRight © 2012-2024 作业小助手 All Rights Reserved. 手机版