In computational complexity theory, non-deterministic space or NSPACE is the computational resource describing the memory space for a non-deterministic Turing machine. It is the non-deterministic counterpart of DSPACE.
The measure NSPACE is used to define the complexity class whose solutions can be determined by a non-deterministic Turing machine. The complexity class NSPACE(f(n)) is the set of decision problems that can be solved by a non-deterministic Turing machine, M, using space O(f(n)), where n is the length of the input.[1]
Several important complexity classes can be defined in terms of NSPACE. These include:
cupk\inNNSPACE(nk)
cupk\inN
nk | |
NSPACE(2 |
)
The Immerman–Szelepcsényi theorem states that NSPACE(s(n)) is closed under complement for every function
A further generalization is ASPACE, defined with alternating Turing machines.
NSPACE is the non-deterministic counterpart of DSPACE, the class of memory space on a deterministic Turing machine. First by definition, then by Savitch's theorem, we have that:
DSPACE[s(n)]\subseteqNSPACE[s(n)]\subseteqDSPACE[(s(n))2].
NSPACE can also be used to determine the time complexity of a deterministic Turing machine by the following theorem:
If a language L is decided in space S(n) (where S(n) ≥ log n) by a non-deterministic TM, then there exists a constant C such that L is decided in time O(CS(n)) by a deterministic one.[2]
The measure of space complexity in terms of DSPACE is useful because it represents the total amount of memory that an actual computer would need to solve a given computational problem with a given algorithm. The reason is that DSPACE describes the space complexity used by deterministic Turing machines, which can represent actual computers. On the other hand, NSPACE describes the space complexity of non-deterministic Turing machines, which are not useful when trying to represent actual computers. For this reason, NSPACE is limited in its usefulness to real-world applications.