mers/examples/04_Greatest_Common_Divisor.mers

31 lines
605 B
Plaintext
Raw Normal View History

2023-10-27 13:50:26 +02:00
gcd := vals -> {
().loop(() -> {
2023-10-27 13:50:26 +02:00
(a, b) := vals
2023-10-27 19:19:42 +02:00
if a.eq(b)
2023-10-27 13:50:26 +02:00
(a)
2023-11-07 20:24:20 +01:00
else if b.subtract(a).signum.eq(1)
&vals = (a, b.subtract(a))
2023-10-27 13:50:26 +02:00
else
2023-11-07 20:24:20 +01:00
&vals = (a.subtract(b), b)
})
}
2023-10-27 13:50:26 +02:00
get_num := () -> {
line := ().read_line.trim
(
line.parse_float,
(
() -> {
("error: '", line, "' not a number!").concat.println
1.panic
}
n -> n,
)
).try
}
("gcd of 899 and 2900 is ", (899, 2900).gcd).concat.println // 29
"Now type two numbers!".println
(a, b) := (().get_num, ().get_num)
("gcd of ", a, " and ", b, " is ", (a, b).gcd).concat.println