Anyone for a game of 'Code Golf'? - FORE!
Like this lesson? Share it with your followers by clicking on the image below.
Anyone who has taught Computing / Computer Science will know that the 'coding and programming' strand can sometimes feel like a very dry topic, especially for young children. One way to inject some fun into your coding lessons is to gamily them!
For those new to the concept, gamification is the process of introducing game-like elements into a traditionally non-gaming contexts to make them more fun and engaging. Gamification strategies include elements such as gamifying grading, incentivizing students with rewards and adding competitive elements such as leaderboards.
One strategy that exemplifies the concept of gamification in the teaching of coding is a game called 'Code Golf'.
What is 'Code Golf'?
I came across the idea of Code Golf at a Computing At School (CAS) conference last summer and have been experimenting with it ever since. The idea is simple, participants are given a problem (or working solution) and are challenged to solve it using the fewest lines of code.
The term Code Golf is derived from the similarity of its scoring system to that of conventional golf, where participants aim to achieve the lowest score possible.
Types of Code Golf
There are two main ways to play Code Golf. The first way requires students to solve a given problem using the fewest lines of code. The second method, which requires a little more preparation from the teacher, requires the students to optimise a given working solution. In both methods, the challenge is for the students to create a solution using the least amount of code. To add a little extra challenge, the teacher can add a Par value (or target number), with the Par being the optimal number of lines of code. This Par value can be altered for different levels of ability (similar to the 'handicap' system in conventional golf) thus allowing the teacher to differentiate the lesson.
Example:
The following is an example of a simple 'Par Challenge'. In this example, students are challenged to create a square using the Python turtle library using 6 lines of code (Par 6).
For those new to the concept, gamification is the process of introducing game-like elements into a traditionally non-gaming contexts to make them more fun and engaging. Gamification strategies include elements such as gamifying grading, incentivizing students with rewards and adding competitive elements such as leaderboards.
One strategy that exemplifies the concept of gamification in the teaching of coding is a game called 'Code Golf'.
What is 'Code Golf'?
I came across the idea of Code Golf at a Computing At School (CAS) conference last summer and have been experimenting with it ever since. The idea is simple, participants are given a problem (or working solution) and are challenged to solve it using the fewest lines of code.
The term Code Golf is derived from the similarity of its scoring system to that of conventional golf, where participants aim to achieve the lowest score possible.
Types of Code Golf
There are two main ways to play Code Golf. The first way requires students to solve a given problem using the fewest lines of code. The second method, which requires a little more preparation from the teacher, requires the students to optimise a given working solution. In both methods, the challenge is for the students to create a solution using the least amount of code. To add a little extra challenge, the teacher can add a Par value (or target number), with the Par being the optimal number of lines of code. This Par value can be altered for different levels of ability (similar to the 'handicap' system in conventional golf) thus allowing the teacher to differentiate the lesson.
Example:
The following is an example of a simple 'Par Challenge'. In this example, students are challenged to create a square using the Python turtle library using 6 lines of code (Par 6).
Working, but inefficient, solution for creating a square in Python using 11 lines of code.
More efficient solution for creating a square using 6 lines of code (or Par 6).
Block-based example
As you can see from the example below, this can also be achieved with block-based languages such as Scratch!
Rationale
Why Turtle?
When introducing students to text-based coding, I always start with the Turtle library in Python. The main reason for this is, when programming the turtle, I often find that students are able to see the immediate impact of their code and are more likely to identify errors in their instructions.
Why Code Golf?
The idea behind Code Golf is to encourage efficient use of code. At GCSE / A-Level, students are required to make efficient use of code in order to access higher grades / mark bands. Efficient code also uses less RAM, compiles quicker and uses up less storage space. Students can use a combination of features such as loops (For, While, Repeat) or sub-routines to achieve their optimised code however, readability and usability must not be sacrificed at the expense of code optimisation therefore, white space and comments do not count as lines; we still want to encourage students to break up and comment their code so that it is comprehensible to others, easier to debug and easy for others to re-use.
When introducing students to text-based coding, I always start with the Turtle library in Python. The main reason for this is, when programming the turtle, I often find that students are able to see the immediate impact of their code and are more likely to identify errors in their instructions.
Why Code Golf?
The idea behind Code Golf is to encourage efficient use of code. At GCSE / A-Level, students are required to make efficient use of code in order to access higher grades / mark bands. Efficient code also uses less RAM, compiles quicker and uses up less storage space. Students can use a combination of features such as loops (For, While, Repeat) or sub-routines to achieve their optimised code however, readability and usability must not be sacrificed at the expense of code optimisation therefore, white space and comments do not count as lines; we still want to encourage students to break up and comment their code so that it is comprehensible to others, easier to debug and easy for others to re-use.
Taking it further
Another 'classic' way to make code more efficient is to remove redundant if statements.
Example:
Challenge: Create a program which simulates the rolling of a six-sided dice. The program must return the result of each dice roll as a word (not a number, for example, if the algorithm returns a 6 then the result displayed must be 'SIX' etc.
Possible solutions:
Example:
Challenge: Create a program which simulates the rolling of a six-sided dice. The program must return the result of each dice roll as a word (not a number, for example, if the algorithm returns a 6 then the result displayed must be 'SIX' etc.
Possible solutions:
Solution 1:
# Dice-roll simulator version 1
import random #Pick a number between 1 and 6 number = random.randint(1,6) if number == 1: print("ONE") elif number == 2: print("TWO") elif number == 3: print("THREE") elif number == 4: print("FOUR") elif number == 5: print("FIVE") else: print("SIX") |
Number of lines of code (not counting comments or blank lines) = 14
Solution 2:
# Dice-roll simulator version 2
import random # List containing each of the 6 sides of a dice. dice=["ONE", "TWO", "THREE", "FOUR", "FIVE", "SIX"] # Pick a number from the list at random. print(random.choice(dice)) |
Number of lines of code (not counting comments or blank lines) = 3
Example Lesson
Learning Objectives:
Curriculum Mapping:
KS2:
KS3:
What you will need:
Challenge
Instruct students to open explore the Python turtle commands (See link above). Once the students have got the hang of turtle, explain to them that they are going to compete in a game of 'Code Golf'. Hand out the challenge (See PowerPoint below) and explain to students that challenge is to solve each of the tasks using the fewest of lines of code possible.
- Understand and use sequence in an algorithm
- Understand and use iteration in an algorithm (FOR and WHILE loops)
Curriculum Mapping:
KS2:
- Design, write and debug programs that accomplish specific goals; solve problems by breaking them into smaller parts. Select, use and combine a variety of software on a range of digital devices to design and create a range of programs.
- Use sequence, selection and repetition in programs; work with variables and various forms of input and output
- Use logical reasoning to explain how some simple algorithms work; detect and correct errors in algorithms and programs
KS3:
- Use two or more programming languages, at least one of which is textual, to solve a variety of computational problems.
What you will need:
- Python 3 (Click here to download the latest version - FREE) or Scratch
- Python Turtle instructions
Challenge
Instruct students to open explore the Python turtle commands (See link above). Once the students have got the hang of turtle, explain to them that they are going to compete in a game of 'Code Golf'. Hand out the challenge (See PowerPoint below) and explain to students that challenge is to solve each of the tasks using the fewest of lines of code possible.
Resources
Click on the link below to download the PowerPoint.
coding_golf.pptx |
Scorecard:
scorecard.xlsx |
Rules
To make the challenge fair and consistent, I recommend that you set some competition rules. Here are the rules I use:
- Blank lines don't count as lines of code.
- Comments don't count as lines of code. (We want to encourage the students to comment their code).
- Import turtle, import random etc. do not count as lines of code.
- Everything else counts.
Like this lesson?
Please share this with your friends / followers and link me in to your tweets (@clcsimon) using the hashtag #CodeGolf
Useful Links
Stack Exchange (Code Golf) - Programming Puzzles & Code Golf Stack Exchange is a question and answer site for programming puzzle enthusiasts and code golfers. It's 100% free, no registration required.
Book of Programming Challenges - Book of programming challenges, ideal for Code Golf , courtesy of Stuart Lucas (Requires sign up to Computing At School - FREE)
Book of Programming Challenges - Book of programming challenges, ideal for Code Golf , courtesy of Stuart Lucas (Requires sign up to Computing At School - FREE)
You may also be interested in:
20 things every computing teacher should try in 2020!
Tags: code golf, coding golf, code optimisation, programming language python, python programming language, python coding language, programming languages python, python code language, python programming language example, what is the python programming language, python scripting, language tutorial, what type of programming language is Python, python class, python how to learn, learn python, learn python from scratch, where to learn Python, coding on computer, computer coding, best place to learn coding online, online coding, online code, computer programming and Coding, hour of code program, computer science degree programs, programs for computer science, what does coding mean in computers, how does computer code work, what is computer programmer.