Arbitrary generation of equation and answer

I am trying to randomly create an equation that also has a 50% chance of being wrong and display this wrong answer. An incorrect answer must have an error of either -2, -1, +1, or +2.

Sometimes my code prints division equations like this (I can't post images): 2/10 = 13 1/5 = 43, etc.

I can't figure out why the equation is displaying a combination of numbers that are not tested together?

(It starts by calling the generateNumbers () function in my onCreateView method

public void generateNumbers() {
    //randomly generate 2 numbers and an operator
    number1 = (int) (Math.random() * 10) + 1;
    number2 = (int) (Math.random() * 10) + 1;
    operator = (int) (Math.random() * 4) + 1;
    //50% chance whether the displayed answer will be right or wrong
    rightOrWrong = (int) (Math.random() * 2) + 1;
    //calculate the offset of displayed answer for a wrong equation (Error)
    error = (int) (Math.random() * 4) + 1;
    generateEquation();
}

public void generateEquation() {
    StringBuilder equation = new StringBuilder();
    //append the first number
    equation.append(number1);
    //generate/append the operator and calculate the real answer
    if (operator == 1) {
        equation.append(" + ");
        actualAnswer = number1 + number2;
    } else if (operator == 2) {
        equation.append(" - ");
        actualAnswer = number1 - number2;
    } else if (operator == 3) {
        equation.append(" x ");
        actualAnswer = number1 * number2;
    } else if (operator == 4) {
        if ((number1%number2==0) && (number1>number2)) {
            actualAnswer = number1 / number2;
        } else {
            generateNumbers();
        }
        equation.append(" / ");

    }
    //append the second number and the equals sign
    equation.append(number2 + " = ");

    //we will display the correct answer for the equation
    if (rightOrWrong == 1) {
        displayedAnswer = actualAnswer;
        equation.append(displayedAnswer);
    }
    //we will display an incorrect answer for the equation
    //need to calculate error (-2, -1, +1, +2)
    else {
        if (error == 1) {
            displayedAnswer = actualAnswer - 1;
        } else if (error == 2) {
            displayedAnswer = actualAnswer - 2;
        }else if (error == 3) {
            displayedAnswer = actualAnswer + 1;
        }else {
            displayedAnswer = actualAnswer + 2;
        }
        //append the displayed answer with error
        equation.append(displayedAnswer);

    }
    questionNumber.setText("You have answered " + count + " out of 20 questions");
    finalEquation.setText(equation.toString());
}

      

+3


source to share


2 answers


I think you need to put an operator return

after the call generateNumbers

in

} else if (operator == 4) {
    if ((number1%number2==0) && (number1>number2)) {
        actualAnswer = number1 / number2;
    } else {
        generateNumbers();
    }
    equation.append(" / ");

}

      



as this will restart the whole process and not continue with more numbers.

+5


source


Modify your code to get rid of the low division chance problem:



public void generateNumbers() {
    number1 = (int) (Math.random() * 10) + 1;
    number2 = (int) (Math.random() * 10) + 1;

    //don't get operator here
    //operator = (int) (Math.random() * 4) + 1;

    rightOrWrong = (int) (Math.random() * 2) + 1;
    error = (int) (Math.random() * 4) + 1;

    //don't generate equation here, start (in the View with generateEquation instead of generate numbers
    //generateEquation();
}

public void generateEquation() {
    StringBuilder equation = new StringBuilder();
    generateNumbers();

    //determine operator here
    operator = (int) (Math.random() * 4) + 1;


    equation.append(number1);
    if (operator == 1) {
        equation.append(" + ");
        actualAnswer = number1 + number2;
    } else if (operator == 2) {
        equation.append(" - ");
        actualAnswer = number1 - number2;
    } else if (operator == 3) {
        equation.append(" x ");
        actualAnswer = number1 * number2;
    } else if (operator == 4) {
        equation.append(" / ");
        // generate new numbers if they are not suiteable
        while((number1%number2!=0) && (number1<number2))
        {
            generateNumbers();
        }
        actualAnswer = number1 / number2;
    }
    ......

      

0


source







All Articles