while loop ends before the question is answered?

r=randi(51)+49;
%the random integer generator will give a number inbetween 50 nad 100 for the user to guess.
disp('I''m thinking of a number between 50 and 100. Can you guess what it is?')
disp('I''m going to have you guess the number and I''ll let you know if it''s right.')
disp(' ')
disp('What is you''re guess')
user_number=input('Please input your number here: ');
clc
%laying the ground rules for the game, so it is clear and easy to understand.
disp('Here''s your guess:')
disp(user_number)
%Making the answer placement more appearent.
count=0;
numguess=0;
chance=0;
while r>=50 || r<=100
r=r;
if user_number==r
disp('Nice job you guessed the right number!')
elseif user_number>r;
disp('You guess is too high. try again.')
user_number=input('enter new guess here');
elseif user_number<r;
disp('Your guessed the wrong number. try again.')
user_number=input('enter new guess here');
end
break
end
%I'm strugling to find a way to continues the loop when the question is asked wrong.

 Accepted Answer

Your break is in the wrong place. It should be under one of the if conditions:
if user_number==r
disp('Nice job you guessed the right number!')
break
And you might give the user better feedback if the guess is too low:
elseif user_number<r;
disp('Your guess is too low. try again.')

7 Comments

When I move the (break) it gives me an endless matrix of the display read out, which was the first problem I ran into. The break was sort of a bandaid, but really thanks for pionting out the second thing.
That's because your while loop condition is wrong. This
while r>=50 || r<=100
should be this
while true
I see where youre coming from, but the problem that Im facing is this contiues matrix that I get in the command window.
this is what I see when I answer the question once.
Your guess is too low of a number. try again.
Your guess is too low of a number. try again.
Your guess is too low of a number. try again.
Your guess is too low of a number. try again.
Your guess is too low of a number. try again.
Your guess is too low of a number. try again.
Your guess is too low of a number. try again.
Your guess is too low of a number. try again.
Your guess is too low of a number. try again........
Please post your current code.
clear all
clc
r=randi(51)+49;
%the random integer generator will give a number inbetween 50 nad 100 for the user to guess.
disp('I''m thinking of a number between 50 and 100. Can you guess what it is?')
disp('I''m going to have you guess the number and I''ll let you know if it''s right.')
disp(' ')
disp('What is you''re guess')
user_number=input('Please input your number here: ');
clc
%laying the ground rules for the game, so it is clear and easy to understand.
disp('Here''s your guess:')
disp(user_number)
%Making the answer placement more appearent.
count=0;
numguess=0;
chance=0;
while r>=50 || r<=100
if user_number==r
disp('Nice job you guessed the right number!')
break
elseif user_number>r
disp('You guess is too high. try again.')
elseif user_number<r
disp('Your guess is too low of a number. try again.')
end
end
user_number=input('enter new guess here');
Why did you move this line outside the loop?
user_number=input('enter new guess here');
It needs to be inside the loop. You had that part correct in your earlier code, but by moving it you made it incorrect. Move it inside the loop. E.g., just before the while end.
end
user_number=input('enter new guess here');
end
wow. didnt even see that I moved that, but actually fixed my problem. thank you bringing that to light

Sign in to comment.

More Answers (2)

while r>=50 || r<=100
Suppose r is 73. Then r>=50 is true so the loop continues.
Suppose r is -6. Then r>=50 is false, but r<=100 is true, so the loop continues.
Suppose r is pi*10^8. Then r>=50 is true, so the loop continues.
The only way that your while loop will terminate is if the user enters NaN, or the user enters something that cannot be compared to numeric, such as a struct. (Or, very obscurely, some handle objects can be compared to numeric and the result will nearly always be 0.)

1 Comment

My issue is that it only give the user one chance to answer. The donain isnt the problem the code is just cutting out before the right answer is given?

Sign in to comment.

could the issue be with the
count=0;
numguess=0;
chance=0;

4 Comments

No, at least for the code you posted. You never use those variables in your code.
do you know what those variables should be? I took those from my related notes, but Im not sure what they do for the code.
the variable names deffinetly need to change. I took them from a something that is a while loop, but it had nothing to do with a guessing game. do you know if the numbers sould even start at 0?
You don't use those variables, so you can delete those lines entirely and it won't make any difference to your code.

Sign in to comment.

Categories

Find more on Loops and Conditional Statements in Help Center and File Exchange

Tags

Community Treasure Hunt

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

Start Hunting!