id/email
password
forgot password | create account
about | help | code help+videos | done | prefs
CodingBat code practice

 

whack_a_mole


In this exercise, we ask you to play a game of whack-a-mole. You will use the strategy: always whack the tallest mole (the one with the most-positive height; if there are several ties with the same height, whack the one that comes first in the list). Keep whacking until there are no more moles with a positive height; then the game is over and you should return a list of two things: the state of the moles after all the whacking, and the list of holes whacked. For example, whack_a_mole([-2, 1, -2]) returns [[-1,-1,-1], [1]], because moles[1] is the highest (at 1), and when you whack it, the result is that all the moles are negative. One complication: if the sum of the mole heights is positive, then the game can never end. (Why?) So in that case, just return the original list of mole heights, followed by None, to indicate that no sequence of holes can finish the game.


whack_a_mole([-2, 1, -2]) → [[-1, -1, -1], [1]]
whack_a_mole([2, -1, -2, 1, -1]) → [[0, -1, 0, 0, 0], [0, 1, 3, 4, 0, 3, 2, 1]]
whack_a_mole([5, 4, 3, 2, 1, -20]) → [[0, 0, -1, 0, -2, -2], [0, 1, 2, 3, 4, 0, 1, 2, 3, 5, 0, 1, 2, 5, 0, 1, 4, 5, 0, 3, 4, 5, 3, 4, 3, 2]]

...Save, Compile, Run (ctrl-enter)

def whack_a_mole(moles):

Editor font size %:
Shorter output


Forget It! -- delete my code for this problem

Progress graphs:
 Your progress graph for this problem
 Random user progress graph for this problem
 Random Epic Progress Graph

Python Help

Difficulty: 223 Post-solution available

Copyright Nick Parlante 2017 - privacy