ElijahCode/project-lvl1-s462

View on GitHub
src/games/gcd.js

Summary

Maintainability
A
0 mins
Test Coverage
import {
  cons,
} from 'hexlet-pairs';
import getRandomNumber from '../utils';
import engine from '../engine';

const gameDescription = 'Find the greatest common divisor of given numbers.';

const findGCD = (num1, num2) => {
  const smallerNumb = (num1 > num2) ? num2 : num1;
  const iter = (divisor, number1, number2) => {
    if (number1 % divisor === 0 && number2 % divisor === 0) {
      return divisor;
    }
    return iter(divisor - 1, number1, number2);
  };
  return iter(smallerNumb, num1, num2);
};

const min = 0;
const max = 100;

const getResult = () => {
  const number1 = getRandomNumber(min, max);
  const number2 = getRandomNumber(min, max);
  const answer = String(findGCD(number1, number2));
  const question = `${number1} ${number2}`;

  return cons(question, answer);
};

const runGame = () => engine(getResult, gameDescription);
export default runGame;