data:image/s3,"s3://crabby-images/eec51/eec511631463682e1bf4fd904f2a1f535faa1cfa" alt=""
Problem Can
-size circuits compute the function
on
defined inductively by
,
,
, and
?
data:image/s3,"s3://crabby-images/10c5a/10c5a9571b36615f7f85732564c38d8e84d2f988" alt="$ O(n) $"
data:image/s3,"s3://crabby-images/71b93/71b930bf005f7c2575e8dc3d55fb4aee46237f83" alt="$ f $"
data:image/s3,"s3://crabby-images/3024e/3024e8180dcdc0ced8bc1e51df778306bb9ff649" alt="$ \{0,1,2\}^* $"
data:image/s3,"s3://crabby-images/fd563/fd563267c458050c0864b752716186e52a60deaf" alt="$ f(\lambda) = \lambda $"
data:image/s3,"s3://crabby-images/f9669/f966948821f80dc824548e60400776c835558929" alt="$ f(0x) = 0f(x) $"
data:image/s3,"s3://crabby-images/c06b2/c06b24ee9493f1a34bd03fba7a21a6b2e1329282" alt="$ f(1x) = 1f(x) $"
data:image/s3,"s3://crabby-images/6f7f7/6f7f76383a3517d6b1ee8c324375fad07591d9ca" alt="$ f(2x) = f(x)2 $"
This function moves all 2s in flush-right, leaving the sequence of 0s and 1s the same, and represents stable topological sort of the partial order
. It is linear-time computable in any model that supports the operations of a double-ended queue in
time, including multi-tape Turing machines, but is to me the "easiest" function for which I do not know linear-size circuits. By contrast sorting
, called the "Dutch National Flag Problem", has
-size circuits by counting. It suffices to compute
when
is a power of
and exactly half the entries are
. For this and more see my Computational Complexity blog item, PDF file here.
Bibliography
* indicates original appearance(s) of problem.