P-99: Ninety-Nine Problems¶
| java | scala | python | lisp |
There is a really famous P-99: Ninety-Nine Prolog Problems.
This is a remake of the P-99: Ninety-Nine Prolog Problems collection that I assembled over several years of teaching at the University of Applied Sciences (Berner Fachhochschule) at Biel-Bienne, Switzerland. The collection is structured into seven sections.
The purpose of this problem collection is to give you the opportunity to practice your skills in logic programming. Your goal should be to find the most elegant solution of the given problems. Efficiency is important, but logical clarity is even more crucial. Some of the (easy) problems can be trivially solved using built-in predicates. However, in these cases, you learn more if you try to find your own solution.
The problems have different levels of difficulty. Those marked with a single asterisk (
*
) are easy. If you have successfully solved the preceeding problems you should be able to solve them within a few (say 15) minutes. Problems marked with two asterisks (**
) are of intermediate difficulty. If you are a skilled Prolog programmer it shouldn’t take you more than 30-90 minutes to solve them. Problems marked with three asterisks (***
) are more difficult. You may need more time (i.e. a few hours or more) to find a good solution.
But, many people have solutions in other programming languages, so I decided to collect them for future references:
- Prolog
- Scala
- S-99: Ninety-Nine Scala Problems. Not all problems have been solved, but close to 90.
- Python
- Python Solutions to 99 Prolog Problems. But only 50 have been solved.
- Lisp
- L-99: Ninety-Nine Lisp Problems. Solved less than 99 problems
- Haskell
- OCaml
- OCaml Exercises. Solved ~99 problems