A community for students.
Here's the question you clicked on:
 0 viewing
ChapLeo
 3 years ago
ok, I'm not quite sure whether I can ask this question, but I don't understand the solution given for the 6th question in Quiz 2. Following is the algorithm I wrote for the cmpGuess function (in order to check my own solution):
def cmpGuess(guess):
""" Assumes that guess is an integer in range(maxVal).
Returns 1 if guess is < magic number, 0 if ==, 1 if > """
magicNumber =4
if guess < magicNumber: return 1
if guess > magicNumber: return 1
if guess == magicNumber: return 0
Is my understanding of the specification of the function right or wrong?
ChapLeo
 3 years ago
ok, I'm not quite sure whether I can ask this question, but I don't understand the solution given for the 6th question in Quiz 2. Following is the algorithm I wrote for the cmpGuess function (in order to check my own solution): def cmpGuess(guess): """ Assumes that guess is an integer in range(maxVal). Returns 1 if guess is < magic number, 0 if ==, 1 if > """ magicNumber =4 if guess < magicNumber: return 1 if guess > magicNumber: return 1 if guess == magicNumber: return 0 Is my understanding of the specification of the function right or wrong?

This Question is Closed

Gianko15
 3 years ago
Best ResponseYou've already chosen the best response.0It'll return those values, 1 for higher than 4, 0 equal to 4, 1 less than 4.

ChapLeo
 3 years ago
Best ResponseYou've already chosen the best response.0That is what I thought as well. The following is the coding given in the solution sheet for question 6 of Quiz 2. Integrating this coding with the above coding doesn't result in the expected solution to the problem. e.g.: if the statement "findNumber(50)" is given, the answer returned is 49, not 4, as it should be. Is the solution given in the marking scheme wrong? or is my coding wrong? Can you please explain this? Thanks def findNumber(maxVal): """ Assumes that maxVal is a positive integer. Returns a number, num, such that cmpGuess(num) == 0 """ s = range(0, maxVal) return bsearch(s, 0, len(s) 1) def bsearch(s, first, last): if (last first) < 2: if cmpGuess(s[first]) == 0: return first else: return last mid = first + (last first)/2 if cmpGuess(s[mid]) == 0: return s[mid] if cmpGuess(s[mid]) == 1: return bsearch(s, first, mid 1) return bsearch(s, mid + 1, last)
Ask your own question
Sign UpFind more explanations on OpenStudy
Your question is ready. Sign up for free to start getting answers.
spraguer
(Moderator)
5
→ View Detailed Profile
is replying to Can someone tell me what button the professor is hitting...
23
 Teamwork 19 Teammate
 Problem Solving 19 Hero
 Engagement 19 Mad Hatter
 You have blocked this person.
 ✔ You're a fan Checking fan status...
Thanks for being so helpful in mathematics. If you are getting quality help, make sure you spread the word about OpenStudy.