BYU logo Computer Science

To start this guide, download this zip file.

Practice with variables

These problems will help you practice with variables. Remember that we can define functions with two parameters:

def go(bit, color):
    """ Given a bit and a color, move and paint that color until blocked """
    while bit.can_move_front():
        bit.move()
        bit.paint(color)

and then call them by passing in the parameters:

go(bit, 'green')

We can also use variables to hold values:

my_color = 'red'

and then pass those variables as parameters:

my_color = 'red'
go(bit, my_color)

Finally, we can get the current color and store it in a variable:

found_color = bit.get_color()

Coloring columns

In this problem, Bit needs to find the color for each column in the world:

a world with some colors in the bottom row

and then fill these colors in the column above:

those colors filled up into the entire column

Planning

How would you solve this problem? Draw out your idea.

work with a friend to solve this problem

Here is a drawing showing one way to think about this problem:

sketch showing while front is clear, get the color, fill the column, go back

  • while the front is clear
    • get the current color
    • fill the column
    • go back

Coding

You can see starter code for this problem in fill_colorful.py:

from byubit import Bit


@Bit.worlds('colors')
def fill_colorful(bit):
    # Write code here
    pass


if __name__ == '__main__':
    fill_colorful(Bit.new_bit)

Let’s put the main loop in fill_colorful():

def fill_colorful(bit):
    while bit.can_move_front():
        color = bit.get_color()
        fill_column(bit, color)
        go_back(bit)
        bit.move()

Then we can write fill_column():

def fill_column(bit, color):
    """
    Fills a column with a given color. Bit starts facing right and ends
    facing up at the top of the column
    """
    bit.turn_left()
    while bit.can_move_front():
        bit.move()
        bit.paint(color)

and we can fill in pass for go_back():

def go_back(bit):
    pass

Let’s see if we got the first part of this problem solved by running the code:

Bit has filled the first column with red

Pretty good!

Now we can fill in go_back():

def go_back(bit):
    """
    Go back to the bottom and turn to the right.
    Bit starts by facing up at the top of the column.
    Bit ends by facing right at the bottom of the column.
    """
    # turn around
    bit.turn_right()
    bit.turn_right()
    # go back
    while bit.can_move_front():
        bit.move()
    # turn
    bit.turn_left()

Let’s run this code to see if we got the logic right to go back:

Bit has filled all the columns except the last one

Nice. So all we need is to do the last column. We can do this by adding a few lines at the end of our main loop:

def fill_colorful(bit):
    while bit.can_move_front():
        color = bit.get_color()
        fill_column(bit, color)
        go_back(bit)
        bit.move()

    # do the last column
    color = bit.get_color()
    fill_column(bit, color)
    go_back(bit)

Bit has filled all the columns

Great!

A few notes

Once you start decomposing problems into multiple functions, you will see that there are lots of ways to solve problems. In this case, we could have put color = bit.get_color() into fill_column(). We also could have written a function fill_column_and_go_back() that called fill_column() and go_back().

Ultimately, how you choose to break down the problem depends on what you think makes your code easiest to read. Maybe this is easier:

def fill_colorful(bit):
    while bit.can_move_front():
        fill_column_and_go_back(bit)
        bit.move()

    # do the last column
    fill_column_and_go_back(bit)

Coloring Ts

Video Transcript

In this problem, Bit starts in a world that provides colored squares:

Three colored squares at the top left

Bit’s job is to get these colors, store them, erase them, and then draw three letter Ts with these colors:

Three colored Ts using these same colors

The colors can be different! There is a second world that starts like this:

Three different colored squares at the top left

Planning

How would you solve this problem? Draw out your idea.

work with a friend to solve this problem

Here is a drawing showing one way to think about this problem:

sketch showing get the colors, go to the start, while front is clear, paint a t three times

  • get each color, store it in a variable, erasing as you go
  • go to the start
  • draw three Ts, one for each color

Coding

We have given you starter code in color_tt.py that provides much of the code you need:

from byubit import Bit


def go(bit):
    """Go until blocked in front."""
    while bit.can_move_front():
        bit.move()


def go_to_start(bit):
    """Bit starts anywhere on the board and ends in the bottom left corner facing right."""
    bit.turn_left()
    bit.turn_left()
    go(bit)
    bit.turn_left()
    go(bit)
    bit.turn_left()


def paint_t(bit, color):
    """Paint a T. Start in the bottom left of the 3x3 box. End just outside the bottom right of the 3x3 box."""
    bit.move()
    bit.turn_left()
    bit.paint(color)
    bit.move()
    bit.paint(color)
    bit.move()
    bit.turn_left()
    bit.move()
    bit.turn_left()
    bit.turn_left()
    bit.paint(color)
    bit.move()
    bit.paint(color)
    bit.move()
    bit.paint(color)
    bit.turn_right()
    bit.move()
    bit.move()
    bit.turn_left()
    bit.move()
    bit.snapshot('T painted')


@Bit.worlds('color_tt', 'color_tt2')
def run(bit):
    pass


if __name__ == '__main__':
    run(Bit.new_bit)

All you need is to fill in the piece of this that collects and erases the colors, then calls the other functions. We can get one of the colors like this:

def run(bit):
    # Get colors
    first_color = bit.get_color()
    bit.paint('white')
    bit.move()

Now just repeat to get all three:

def run(bit):
    # Get colors
    first_color = bit.get_color()
    bit.paint('white')
    bit.move()

    second_color = bit.get_color()
    bit.paint('white')
    bit.move()

    third_color = bit.get_color()
    bit.paint('white')
    bit.move()

Then call the other functions we provided:

def run(bit):
    # Get colors
    first_color = bit.get_color()
    bit.paint('white')
    bit.move()

    second_color = bit.get_color()
    bit.paint('white')
    bit.move()

    third_color = bit.get_color()
    bit.paint('white')
    bit.move()
    bit.snapshot('Got colors')

    go_to_start(bit)
    bit.snapshot('At start')

    paint_t(bit, first_color)
    paint_t(bit, second_color)
    paint_t(bit, third_color)

We have added bit.snapshot() so that you can easily step through the code and see how it works.