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 are the advantages of prototyping?
What is difference between initialization and assignment?
12 Answers HCL, HP, Infosys,
What is the use of bit fields in structure declaration?
What is a dll entry point?
What is the maximum value of a unsigned char a) 255 b) 256 c) 128
Describe delete operator?
const char * char * const What is the differnce between the above two?
What is a local variable?
What is switch case in c++ syntax?
what is the emaning of '#include" "'?
What are the uses of static class data?
What return value must conversion operators have in their declaration?