## Solution for

Programming Exercise 3.1

THIS PAGE DISCUSSES ONE POSSIBLE SOLUTION to the following exercise from this on-line Java textbook.

Exercise 3.1:How many times do you have to roll a pair of dice before they come up snake eyes? You could do the experiment by rolling the dice by hand. Write a computer program that simulates the experiment. The program should report the number of rolls that it makes before the dice come up snake eyes. (Note: "Snake eyes" means that both dice show a value of 1.) Exercise 2.2 explained how to simulate rolling a pair of dice.

Discussion

Since we want to roll the dice at least once, a

do..whileis appropriate. A pseudocode algorithm for the program isLet countRolls = 0 do: roll the dice count this roll by adding 1 to countRolls while the roll is not snake eyes Output the value of countRollsAs in Exercise 2.2, we can simulate rolling one die by computing

(int)(Math.random()*6) + 1.We want to

stoprolling the dice when the roll is a double 1. We want tocontinuerolling the dice while the roll isnota double 1. Ifdie1anddie2are variables representing the values of the dice, the condition for continuing to roll can be expressed aswhile ( ! (die1 == 1 && die2 == 1) )The exclamation point means "not", so the condition says that it is not the case that both

die1is 1 anddie2is 1. That is, it is not the case that the dice came up snake eyes. Another way to express the same condition is that at least one of the dice is not 1, that is, that eitherdie1is not 1ordie2is not 1. In java code, this is written:while ( die1 != 1 || die2 != 1 )This is the test that I use in my program. Students often get the

&&and||operators mixed up, especially when negation is involved. (In this case, we could have avoided the problem by testingwhile (die1+die2 != 2).)Filling in some details gives an algorithm that can be easily converted into a program:

Let countRolls = 0 do: die1 = (int)(Math.random()*6) + 1 die2 = (int)(Math.random()*6) + 1 count this roll by adding 1 to countRolls while die1 is not 1 or die2 is not 1 Output the value of countRolls

The Solution

public class SnakeEyes { /* This program simulates rolling a pair of dice until they come up snake eyes. It reports how many rolls were needed. */ public static void main(String[] args) { int die1, die2; // The values rolled on the two dice. int countRolls; // Used to count the number of rolls. countRolls = 0; do { die1 = (int)(Math.random()*6) + 1; // roll the dice die2 = (int)(Math.random()*6) + 1; countRolls++; // and count this roll } while ( die1 != 1 || die2 != 1 ); System.out.println("It took " + countRolls + " rolls to get snake eyes."); } // end main() } // end class

[ Exercises | Chapter Index | Main Index ]