17.6. Classes of Problems


Classes of problems

A set of problems is usually called a class.

It is important to remember that a class of problems is not a class of algorithms.


Finite-state computation

A decision problem solvable with a fixed amount of memory (by a finite-state machine) is called a finite-state or regular language.

So finite-state machines define the class of all decision problems that can be solved by finite-state machines.


Computable and uncomputable problems

Problems solvable by deterministic Turing-machine algorithms are called computable. That is, deterministic Turing machines define the class of computable problems.

But remember that no Turing machine can be in the class of computable problems, since a Turing machine is not a problem.

All of the problems solved every day by computers are obviously computable. But there are problems that are not computable. Examples are the Halting Problem (shown uncomputable here) and Hilbert's Tenth Problem.


Partially computable problems

Problems solvable by partial algorithms on Turing machines are called partially computable. Both the Halting Problem and Hilbert's Tenth Problem are partially computable.

There are problems that are so difficult they are not even partially computable. An example is the set of all programs that halt on every input: {p | ∀xp(x)↓)}.


Polynomial time and space

We looked at resource-limited computation, focusing on problems computable in polynomial time or polynomial space.

We defined the following complexity classes.


Relationships among classes

Known relationships are:

You should be prepared to give a definition of each of the classes mentioned on this page and you should know the relationships that have been stated.