Write a C++ program that asks the user to choose a number
between 1 and 1000. Then,
your program should be able to guess the number by asking
the user no more than 10 yes/no
questions. Use a while loop in your program
Answer / i4o
Instead of giving the full program the expectation of this question could be logical skills or applying heuristics in deducing the given problem domain (1-1000) in to smaller pieces. The decision tree could be like whether the number could be even or odd thus eliminating 50% then based on number of digits etc. But it expects to use while loop. So it should be solved mathematically. The following snippet (C#) uses the something similar to binary search (Cutting the problem domain exactly by half each time) and any number could be cracked with 10 questions.
static void Main(string[] args)
{
int low = 1, high = 1000;
int mean;
string userresponse;
while (low != high)
{
mean = (low + high) / 2;
Console.WriteLine("Is the number between {0} & {1}", low, mean);
userresponse = Console.ReadLine();
if (userresponse.CompareTo("y") == 0)
{
high = mean;
}
else
{
low = mean+1;
}
}
Console.Write("You Guessed : {0}", low);
Console.Read();
}
Is This Answer Correct ? | 4 Yes | 0 No |
What will happen if when say delete this ?
Is swift faster than go?
What is exception handling? Does c++ support exception handling?
Where the memory to the static variables is allocated?
How does c++ structure differ from c++ class?
Explain deep copy?
What do you mean by function and operator overloading in c++?
What is the difference between structures and unions?
Specify different types of decision control statements?
What you know about structures in C++?
0 Answers Agilent, ZS Associates,
How can I improve my c++ skills?
What is double in c++?