how can I use a while loop for LCM?

1 回表示 (過去 30 日間)
Lorayne Reyes
Lorayne Reyes 2018 年 6 月 12 日
回答済み: Matt Dickson 2018 年 6 月 12 日
I want to write a program that will allow me to add the value of 'x', and then if the sum is equal to the input for y stop and display that value as the LCM. But, if not, add y+y+y+y.... until x=y.
  1 件のコメント
Paridhi Yadav
Paridhi Yadav 2018 年 6 月 12 日
Can you explain clearly what you want ?

サインインしてコメントする。

回答 (1 件)

Matt Dickson
Matt Dickson 2018 年 6 月 12 日
To do it iteratively as you laid out, you'd have something like
function [leastCommon] = lcm(a,b)
a1 = a;
b2 = b;
while a1 ~= b1
if a1 > b1
b1 = b1 + b;
else
a1 = a1 + a;
end
end
leastCommon = a1;
end
I'm not sure if you're set on doing it the way you described, but a simpler way to find the LCM is to use the greatest common division (GCD). Say you want to know the LCM of two numbers, a and b. Then
LCM = (a * b) / gcd(a,b)
The GCD is easy to find via the Euclidean algorithm, which is recursively defined as
function [ret] = gcd(a, b)
if b == 0
ret = a;
else
ret = gcd(b, mod(a, b));
end

カテゴリ

Help Center および File ExchangeDiscrete Math についてさらに検索

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by