### Add new exercises to Lisp Flavoured Erlang (LFE)

One of the easiest ways to add new exercises to the Lisp Flavoured Erlang (LFE) track is to translate them from other language tracks on Exercism. This page lists all of the exercises that exist on Exercism, but have not yet been implemented in Lisp Flavoured Erlang (LFE).

The
icon links to the generic, language-independent problem description

The
icon links to the canonical test data

The language icons link to each existing implementation of the problem.

Once you've picked an exercise, follow the instructions in the Contributing Guide and submit your pull request to the Lisp Flavoured Erlang (LFE) track repository on GitHub.

### Hello World

The classical introductory exercise. Just say "Hello, World!"

### Raindrops

Convert a number to a string, the contents of which depend on the number's factors.

### Roman Numerals

Write a function to convert from normal numbers to Roman Numerals.

### Triangle

Determine if a triangle is equilateral, isosceles, or scalene.

### Scrabble Score

Given a word, compute the scrabble score for that word.

### Robot Name

Manage robot factory settings.

### Pangram

Determine if a sentence is a pangram.

### Sieve

Use the Sieve of Eratosthenes to find all the primes from 2 up to a given number.

### Nth Prime

Given a number n, determine what the nth prime is.

### All Your Base

Convert a number, represented as a sequence of digits in one base, to any other base.

### Bracket Push

Make sure the brackets and braces all match.

### Pascals Triangle

Compute Pascal's triangle up to a given number of rows.

### Acronym

Convert a long phrase to its acronym

### Crypto Square

Implement the classic method for composing secret messages called a square code.

### 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.

### Wordy

Parse and evaluate simple math word problems returning the answer as an integer.

### Binary Search

Implement a binary search algorithm.

### Isogram

Determine if a word or phrase is an isogram.

### Perfect Numbers

Determine if a number is perfect, abundant, or deficient based on Nicomachus' (60 - 120 CE) classification scheme for natural numbers.

### Prime Factors

Compute the prime factors of a given natural number.

### Minesweeper

Add the numbers to a minesweeper board

### Say

Given a number from 0 to 999,999,999,999, spell out that number in English.

### Custom Set

Create a custom set type.

### Ocr Numbers

Given a 3 x 4 grid of pipes, underscores, and spaces, determine which number is represented, or whether it is garbled.

### Pig Latin

Implement a program that translates from English to Pig Latin

### Secret Handshake

Given a decimal number, convert it to the appropriate sequence of events for a secret handshake.

### Binary Search Tree

Insert and search for numbers in a binary tree.

### Linked List

Implement a doubly linked list

### Kindergarten Garden

Given a diagram, determine which plants each child in the kindergarten class is responsible for.

### Palindrome Products

Detect palindrome products in a given range.

### Pythagorean Triplet

There exists exactly one Pythagorean triplet for which a + b + c = 1000. Find the product a * b * c.

### Run Length Encoding

Implement run-length encoding and decoding.

### Food Chain

Generate the lyrics of the song 'I Know an Old Lady Who Swallowed a Fly'

### List Ops

Implement basic list operations

### Matrix

Given a string representing a matrix of numbers, return the rows and columns of that matrix.

### Saddle Points

Detect saddle points in a matrix.

### Simple Cipher

Implement a simple shift cipher like Caesar and a more secure substitution cipher

### Sublist

Write a function to determine if a list is a sublist of another list.

### Flatten Array

Take a nested list and return a single list with all values except nil/null

### Change

Correctly determine change to be given using the least number of coins

### Diamond

Given a letter, print a diamond starting with 'A' with the supplied letter at the widest point.

### House

Output the nursery rhyme 'This is the House that Jack Built'.

### Connect

Compute the result for a game of Hex / Polygon

### React

Implement a basic reactive system.

### Simple Linked List

Write a simple linked list implementation that uses Elements and a List

### Dominoes

Make a chain of dominoes.

### Forth

Implement an evaluator for a very simple subset of Forth

### Poker

Pick the best hand(s) from a list of poker hands.

### Transpose

Take input text and output it transposed.

### Twelve Days

Output the lyrics to 'The Twelve Days of Christmas'

### Alphametics

Write a function to solve alphametics puzzles.

### Protein Translation

Translate RNA sequences into proteins.

### Rail Fence Cipher

Implement encoding and decoding for the rail fence cipher.

### Tournament

Tally the results of a small football competition.

### Variable Length Quantity

Implement variable length quantity encoding and decoding.

### Zipper

Creating a zipper for a binary tree.

### Pov

Reparent a graph on a selected node

### Rectangles

Count the rectangles in an ASCII diagram.

### Book Store

To try and encourage more sales of different books from a popular 5 book series, a bookshop has decided to offer discounts of multiple-book purchases.

### Grep

Search a file for lines matching a regular expression pattern. Return the line number and contents of each matching line.

### Two Bucket

Given two buckets of different size, demonstrate how to measure an exact number of liters.

### Word Search

Create a program to solve a word search puzzle.

### Diffie Hellman

Diffie-Hellman key exchange.

### Markdown

Refactor a Markdown parser

### Proverb

For want of a horseshoe nail, a kingdom was lost, or so the saying goes. Output the full text of this proverbial rhyme.

### Rotational Cipher

Create an implementation of the rotational cipher, also sometimes called the Caesar cipher.

### Sgf Parsing

Parsing a Smart Game Format string.

### Dot Dsl

Write a Domain Specific Language similar to the Graphviz dot language

### Go Counting

Count the scored points on a Go board.

### Hangman

Implement the logic of the hangman game using functional reactive programming.

### Ledger

Refactor a ledger printer.

### Lens Person

Use lenses to update nested records (specific to languages with immutable data).

### Scale Generator

Generate musical scales, given a starting note and a set of intervals.

### Tree Building

Refactor a tree building algorithm.

### Error Handling

Implement various kinds of error handling and resource management

### Paasio

Report network IO statistics