Sign up
Log in
Home
Language Tracks
Haskell Track
Exercises
Join the Haskell Track
Exercises on the Haskell Track
94 exercises to help you master Haskell
medium
easy
Hello World
The classical introductory exercise. Just say "Hello, World!"
misc
medium
easy
Leap
Given a year, report if it is a leap year.
misc
medium
easy
Space Age
Given an age in seconds, calculate how old someone is in terms of a given planet's solar years.
misc
medium
easy
Bob
Bob is a lackadaisical teenager. In conversation, his responses are very limited.
misc
medium
easy
Pangram
Determine if a sentence is a pangram.
misc
medium
easy
Collatz Conjecture
Calculate the number of steps to reach 1 using the Collatz conjecture
maybe
number theory
medium
easy
Rna Transcription
Given a DNA strand, return its RNA Complement Transcription.
maybe
medium
easy
Sum Of Multiples
Given a number, find the sum of all the multiples of particular numbers up to but not including that number.
number theory
medium
easy
Difference Of Squares
Find the difference between the square of the sum and the sum of the squares of the first N natural numbers.
number theory
medium
easy
Grains
Calculate the number of grains of wheat on a chessboard given that the number on each square doubles.
maybe
number theory
medium
easy
Acronym
Convert a long phrase to its acronym
misc
medium
easy
Perfect Numbers
Determine if a number is perfect, abundant, or deficient based on Nicomachus' (60 - 120 CE) classification scheme for natural numbers.
maybe
number theory
medium
easy
Hamming
Calculate the Hamming difference between two DNA strands.
maybe
medium
easy
Nucleotide Count
Given a DNA string, compute how many times each nucleotide occurs in the string.
either
medium
easy
Grade School
Given students' names along with the grade that they are in, create a roster for the school
define type
medium
easy
Isogram
Determine if a word or phrase is an isogram.
misc
medium
easy
Diamond
Given a letter, print a diamond starting with 'A' with the supplied letter at the widest point.
misc
medium
easy
Etl
We are going to do the `Transform` step of an Extract-Transform-Load.
misc
medium
easy
Raindrops
Convert a number to a string, the contents of which depend on the number's factors.
misc
medium
easy
Accumulate
Implement the `accumulate` operation, which, given a collection and an operation to perform on each element of the collection, returns a new collection containing the result of applying that operation to each element of the input collection.
lazy evaluation
library reimplementation
medium
easy
Strain
Implement the `keep` and `discard` operation on collections. Given a collection and a predicate on the collection's elements, `keep` returns a new collection containing those elements where the predicate is true, while `discard` returns a new collection containing those elements where the predicate is false.
lazy evaluation
library reimplementation
medium
easy
Phone Number
Clean up user-entered phone numbers so that they can be sent SMS messages.
maybe
medium
easy
Twelve Days
Output the lyrics to 'The Twelve Days of Christmas'
misc
medium
easy
Isbn Verifier
Check if a given string is a valid ISBN-10 number.
misc
medium
easy
Run Length Encoding
Implement run-length encoding and decoding.
misc
medium
easy
Beer Song
Produce the lyrics to that beloved classic, that field-trip favorite: 99 Bottles of Beer on the Wall.
refactoring
medium
easy
Triangle
Determine if a triangle is equilateral, isosceles, or scalene.
number theory
medium
easy
Scrabble Score
Given a word, compute the scrabble score for that word.
misc
medium
easy
Kindergarten Garden
Given a diagram, determine which plants each child in the kindergarten class is responsible for.
define type
medium
easy
Complex Numbers
Implement complex numbers.
define type
number theory
medium
easy
Robot Simulator
Write a robot simulator.
define type
medium
easy
Secret Handshake
Given a decimal number, convert it to the appropriate sequence of events for a secret handshake.
misc
medium
easy
Protein Translation
Translate RNA sequences into proteins.
maybe
medium
medium
Anagram
Given a word and a list of possible anagrams, select the correct sublist.
misc
medium
medium
Simple Linked List
Write a simple linked list implementation that uses Elements and a List
define type
library reimplementation
medium
medium
List Ops
Implement basic list operations
accumulator strictness
library reimplementation
medium
medium
Meetup
Calculate the date of meetups.
misc
medium
medium
Roman Numerals
Write a function to convert from normal numbers to Roman Numerals.
maybe
medium
medium
Prime Factors
Compute the prime factors of a given natural number.
number theory
medium
medium
Allergies
Given a person's allergy score, determine whether or not they're allergic to a given item, and their full list of allergies.
misc
medium
medium
All Your Base
Convert a number, represented as a sequence of digits in one base, to any other base.
either
medium
medium
Largest Series Product
Given a string of digits, calculate the largest product for a contiguous substring of digits of length n.
either
medium
medium
Clock
Implement a clock that handles times without dates.
define type
instance num
medium
medium
Matrix
Given a string representing a matrix of numbers, return the rows and columns of that matrix.
define type
medium
medium
House
Output the nursery rhyme 'This is the House that Jack Built'.
refactoring
medium
medium
Pascals Triangle
Compute Pascal's triangle up to a given number of rows.
number theory
medium
medium
Pythagorean Triplet
There exists exactly one Pythagorean triplet for which a + b + c = 1000. Find the product a * b * c.
number theory
medium
medium
Saddle Points
Detect saddle points in a matrix.
misc
medium
medium
Series
Given a string of digits, output all the contiguous substrings of length `n` in that string.
misc
medium
medium
Sieve
Use the Sieve of Eratosthenes to find all the primes from 2 up to a given number.
number theory
medium
medium
Atbash Cipher
Create an implementation of the atbash cipher, an ancient encryption system created in the Middle East.
misc
medium
medium
Bracket Push
Make sure the brackets and braces all match.
stack
medium
medium
Crypto Square
Implement the classic method for composing secret messages called a square code.
misc
medium
medium
Nth Prime
Given a number n, determine what the nth prime is.
maybe
number theory
medium
medium
Word Count
Given a phrase, count the occurrences of each word in that phrase.
misc
medium
medium
Binary Search Tree
Insert and search for numbers in a binary tree.
define type
maybe
medium
medium
Luhn
Given a number determine whether or not it is valid per the Luhn formula.
misc
medium
medium
Queen Attack
Given the position of two queens on a chess board, indicate whether or not they are positioned so that they can attack each other.
maybe
medium
medium
Ocr Numbers
Given a 3 x 4 grid of pipes, underscores, and spaces, determine which number is represented, or whether it is garbled.
misc
medium
medium
Food Chain
Generate the lyrics of the song 'I Know an Old Lady Who Swallowed a Fly'
refactoring
medium
medium
Rotational Cipher
Create an implementation of the rotational cipher, also sometimes called the Caesar cipher.
misc
medium
medium
Spiral Matrix
Given the size, return a square matrix of numbers in spiral order.
misc
medium
medium
Custom Set
Create a custom set type.
define type
library reimplementation
medium
medium
Parallel Letter Frequency
Count the frequency of letters in texts using parallel computation.
misc
medium
medium
Transpose
Take input text and output it transposed.
misc
medium
medium
Simple Cipher
Implement a simple shift cipher like Caesar and a more secure substitution cipher
io monad
mutable state
random
medium
medium
Palindrome Products
Detect palindrome products in a given range.
misc
medium
medium
Robot Name
Manage robot factory settings.
define type
io monad
random
medium
medium
Pig Latin
Implement a program that translates from English to Pig Latin
misc
medium
medium
Say
Given a number from 0 to 999,999,999,999, spell out that number in English.
maybe
medium
medium
Bank Account
Simulate a bank account supporting opening/closing, withdraws, and deposits of money. Watch out for concurrent transactions!
define type
io monad
maybe
mutable state
medium
medium
Sublist
Write a function to determine if a list is a sublist of another list.
misc
medium
medium
Rail Fence Cipher
Implement encoding and decoding for the rail fence cipher.
misc
medium
medium
Linked List
Implement a doubly linked list
define type
io monad
library reimplementation
maybe
mutable state
medium
medium
Zebra Puzzle
Solve the zebra puzzle.
misc
medium
medium
Minesweeper
Add the numbers to a minesweeper board
misc
medium
medium
Wordy
Parse and evaluate simple math word problems returning the answer as an integer.
maybe
medium
medium
Change
Correctly determine change to be given using the least number of coins
maybe
medium
medium
Alphametics
Write a function to solve alphametics puzzles.
maybe
medium
medium
Bowling
Score a bowling game
either
medium
medium
Poker
Pick the best hand(s) from a list of poker hands.
maybe
medium
hard
Connect
Compute the result for a game of Hex / Polygon
maybe
medium
hard
Dominoes
Make a chain of dominoes.
maybe
medium
hard
Sgf Parsing
Parsing a Smart Game Format string.
maybe
medium
hard
Go Counting
Count the scored points on a Go board.
maybe
medium
hard
Lens Person
Use lenses to update nested records (specific to languages with immutable data).
misc
medium
hard
Zipper
Creating a zipper for a binary tree.
define type
maybe
medium
hard
Forth
Implement an evaluator for a very simple subset of Forth
define type
either
stack
medium
hard
Pov
Reparent a graph on a selected node
maybe
medium
Binary
Convert a binary number, represented as a string (e.g. '101010'), to its decimal equivalent using first principles
misc
medium
Gigasecond
Calculate the moment when someone has lived for 10^9 seconds.
misc
medium
Hexadecimal
Convert a hexadecimal number, represented as a string (e.g. "10af8c"), to its decimal equivalent using first principles (i.e. no, you may not use built-in or external libraries to accomplish the conversion).
misc
medium
Octal
Convert a octal number, represented as a string (e.g. '1735263'), to its decimal equivalent using first principles (i.e. no, you may not use built-in or external libraries to accomplish the conversion).
misc
medium
Trinary
Convert a trinary number, represented as a string (e.g. '102012'), to its decimal equivalent using first principles.
misc