anonymous
  • anonymous
I apologize for the duplicate question. I closed the previous one by accident. I've just started this course and I have the book. I did the finger exercise after section 2.2 and am quite pleased that it worked. The finger exercise after section 2.4 seems to be solvable by the same method, but it becomes tedious to enter and compare 10 variables. I wanted to do it with only 2 variables and a loop. I was able to, but only by setting the initial value of one variable to an arbitrary low negative value. This seems a bit of a cheat. Is there a more elegant way to do this or is this an acceptable technique? ------------------- print 'Given ten integers, this program will tell the highest odd.' count = 0 y = -999999999999 for count in range (0, 10): x = int(raw_input('Enter an integer.')) if x>=y and (abs(x)%2)==1: y = x count = count + 1 if y ==-999999999999: print 'All of the inputs are even.' else: print y, 'is the greatest odd.'
MIT 6.00 Intro Computer Science (OCW)
  • Stacey Warren - Expert brainly.com
Hey! We 've verified this expert answer for you, click below to unlock the details :)
SOLVED
At vero eos et accusamus et iusto odio dignissimos ducimus qui blanditiis praesentium voluptatum deleniti atque corrupti quos dolores et quas molestias excepturi sint occaecati cupiditate non provident, similique sunt in culpa qui officia deserunt mollitia animi, id est laborum et dolorum fuga. Et harum quidem rerum facilis est et expedita distinctio. Nam libero tempore, cum soluta nobis est eligendi optio cumque nihil impedit quo minus id quod maxime placeat facere possimus, omnis voluptas assumenda est, omnis dolor repellendus. Itaque earum rerum hic tenetur a sapiente delectus, ut aut reiciendis voluptatibus maiores alias consequatur aut perferendis doloribus asperiores repellat.
katieb
  • katieb
I got my questions answered at brainly.com in under 10 minutes. Go to brainly.com now for free help!
anonymous
  • anonymous
If you want, you can set y == 0 and build on to your if statement a bit: for count in range (0, 10): x = int(raw_input('Enter an integer.')) -> if y==0 and (abs(x)%2)==1: y = x -> if x>=y and (abs(x)%2)==1: -> y = x y = x count = count + 1 I think that will set y to the first odd number entered and the (x)%2==1 check makes sure user can't change it back to 0. I don't know if it's any more elegant but it does get rid of all those 9's. P.S. I'm sorry if this notifies you each time someone answers your question, I kept making spelling errors and then having to delete and retype.
anonymous
  • anonymous
it is not a cheat if it works (or even if it doesn't). use a list. put all the odd integers in the list. then use the max() function to find the largest. http://docs.python.org/2.7/tutorial/introduction.html#lists http://docs.python.org/2.7/library/stdtypes.html#sequence-types-str-unicode-list-tuple-bytearray-buffer-xrange http://docs.python.org/2.7/library/functions.html#max or change your logic a bit. http://dpaste.com/954812/
anonymous
  • anonymous
The `count = count + 1` line in your code is not necessary. `range(10)` produces a list with 1, 2, 3, ..., 10 and at the end of the loop, it will automatically advance to the next item in the list, ignoring the value you just updated it to.

Looking for something else?

Not the answer you are looking for? Search for more explanations.

More answers

anonymous
  • anonymous
Thanks to all three of you! My program to sort 10 inputs is now shorter than the original one to sort 3 inputs. I find this very cool. I appreciate your comments. I will try to be useful to some other people as we go along.

Looking for something else?

Not the answer you are looking for? Search for more explanations.