Least Common Multiple
 
 Unlike other functions around, we will define lcm below instead of
  axiomatizing it. Indeed, there is no "prior art" about lcm in the
  standard library to be compliant with, and the generic definition
  of lcm via gcd is quite reasonable.
 
  By the way, we also state here some combined properties of div/mod
  and gcd.
 
We now define lcm thanks to gcd:
 
    lcm a b = a * (b / gcd a b)
            = (a / gcd a b) * b
            = (a*b) / gcd a b
 
   Nota: 
lcm 0 0 should be 0, which isn't garantee with the third
   equation above.