While cycle with conditions never ending

17 visualizaciones (últimos 30 días)
Jan
Jan el 27 de Ag. de 2024
Comentada: Jan el 6 de Sept. de 2024
Hi,
I have to simulate dice rolls and count rolls until I got 6 twice in a row. I have this code:
clear all
close all
clc
rng("shuffle");
Dice1 = 0;
Dice2 = 1;
s=0;
while (Dice1&&Dice2)~=6
Dice1 = Dice2;
Dice2 = randi(6);
s=s+1;
end
And it never stops. I believe I have conditon set correctly because when Dice1 and Dice2 are both manually set to 6, I got logical 0. Where is a problem?

Respuesta aceptada

Piyush Kumar
Piyush Kumar el 27 de Ag. de 2024
It looks like there’s a small issue with the condition in your while loop. The condition (Dice1 && Dice2) ~= 6 is not checking if both Dice1 and Dice2 are equal to 6. Instead, it’s checking if the logical AND of Dice1 and Dice2 is not equal to 6, which is not what you want.
You should change the condition to check if both Dice1 and Dice2 are equal to 6. Here’s the corrected code:
clear all
close all
clc
rng("shuffle");
Dice1 = 0;
Dice2 = 1;
s = 0;
while ~(Dice1 == 6 && Dice2 == 6)
Dice1 = Dice2;
Dice2 = randi(6);
s = s + 1;
end
disp(['Number of rolls: ', num2str(s)]);

Más respuestas (2)

dpb
dpb el 27 de Ag. de 2024
Editada: dpb el 27 de Ag. de 2024
while ~(Dice1==6 & Dice2==6)
The expression as written first does AND operation of the two numeric, not logic, values and then tests that.
Dice1=6; Dice2=Dice1;
Dice1&Dice2
ans = logical
1
is a logical True, but it isn't ==6 and anything where both operands are nonzero will produce the same result.

Steven Lord
Steven Lord el 27 de Ag. de 2024
while (Dice1&&Dice2)~=6
This line of code doesn't do what you think it does.
(Dice1 && Dice2) is either true (if both Dice1 and Dice2 are non-zero) or false (if either is zero.) True is not equal to 6 and neither is false, so this while condition is always satisfied regardless of the value of (Dice1 && Dice2). Therefore you cannot break out of the loop.
You might think that (Dice1 ~= 6 && Dice2 ~= 6) is the right approach. Try working through it with Dice1 equal to 6 and Dice2 equal to 5. Should the loop repeat in that scenario? Does it?
Write out the condition in words not code and pay attention to the single word conjunction you use to combine the two clauses. "I want the loop to repeat while <blah1> <conjunction> <blah2>". Did you use "and" or "either/or" to combine blah1 and blah2?
  1 comentario
Jan
Jan el 6 de Sept. de 2024
thanks for the answer.
The correct condition is
while ~(Dice1 == 6 && Dice2 == 6)
. My condition in words I want the loop to repeat while <dice1 is not equal to six> <and> <dice2 is not equal to six>.
I also tried before coming here
(Dice1 ~= 6 && Dice2 ~= 6)
but it didn't work too and I think that's exactly my word condition in the code

Iniciar sesión para comentar.

Categorías

Más información sobre Programming en Help Center y File Exchange.

Etiquetas

Productos


Versión

R2024a

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by