New search (restrictions: 1 < n < 15, 1 < k < 15, k^n < 50000 )
See below for more info about Bruijn sequences.
You may also want try my de Bruijn sequence Java Applet.
de Bruijn sequence, k=10, n=3
The following is a de Bruijn sequence of a k=10 sized alphabet with
string length of n=3 . Please note that the sequence is circular, i.e. it wraps "around the end", indicated by setting the first n-1 digits last in the sequence (inside parenthesis).
Sequence length: k^n = 10^3 = 1000 (with the "wrap": k^n+(n-1) = 10^3+(3-1) = 1002)
Sequence:
0 0 0 1 0 0 2 0 0 3 0 0 4 0 0 5 0 0 6 0 0 7 0 0 8 0 0 9 0 1 1 0 1 2 0 1 3 0 1 4 0 1 5 0 1 6 0 1 7 0 1 8 0 1 9 0 2 1 0 2 2 0 2 3 0 2 4 0 2 5 0 2 6 0 2 7 0 2 8 0 2 9 0 3 1 0 3 2 0 3 3 0 3 4 0 3 5 0 3 6 0 3 7 0 3 8 0 3 9 0 4 1 0 4 2 0 4 3 0 4 4 0 4 5 0 4 6 0 4 7 0 4 8 0 4 9 0 5 1 0 5 2 0 5 3 0 5 4 0 5 5 0 5 6 0 5 7 0 5 8 0 5 9 0 6 1 0 6 2 0 6 3 0 6 4 0 6 5 0 6 6 0 6 7 0 6 8 0 6 9 0 7 1 0 7 2 0 7 3 0 7 4 0 7 5 0 7 6 0 7 7 0 7 8 0 7 9 0 8 1 0 8 2 0 8 3 0 8 4 0 8 5 0 8 6 0 8 7 0 8 8 0 8 9 0 9 1 0 9 2 0 9 3 0 9 4 0 9 5 0 9 6 0 9 7 0 9 8 0 9 9 1 1 1 2 1 1 3 1 1 4 1 1 5 1 1 6 1 1 7 1 1 8 1 1 9 1 2 2 1 2 3 1 2 4 1 2 5 1 2 6 1 2 7 1 2 8 1 2 9 1 3 2 1 3 3 1 3 4 1 3 5 1 3 6 1 3 7 1 3 8 1 3 9 1 4 2 1 4 3 1 4 4 1 4 5 1 4 6 1 4 7 1 4 8 1 4 9 1 5 2 1 5 3 1 5 4 1 5 5 1 5 6 1 5 7 1 5 8 1 5 9 1 6 2 1 6 3 1 6 4 1 6 5 1 6 6 1 6 7 1 6 8 1 6 9 1 7 2 1 7 3 1 7 4 1 7 5 1 7 6 1 7 7 1 7 8 1 7 9 1 8 2 1 8 3 1 8 4 1 8 5 1 8 6 1 8 7 1 8 8 1 8 9 1 9 2 1 9 3 1 9 4 1 9 5 1 9 6 1 9 7 1 9 8 1 9 9 2 2 2 3 2 2 4 2 2 5 2 2 6 2 2 7 2 2 8 2 2 9 2 3 3 2 3 4 2 3 5 2 3 6 2 3 7 2 3 8 2 3 9 2 4 3 2 4 4 2 4 5 2 4 6 2 4 7 2 4 8 2 4 9 2 5 3 2 5 4 2 5 5 2 5 6 2 5 7 2 5 8 2 5 9 2 6 3 2 6 4 2 6 5 2 6 6 2 6 7 2 6 8 2 6 9 2 7 3 2 7 4 2 7 5 2 7 6 2 7 7 2 7 8 2 7 9 2 8 3 2 8 4 2 8 5 2 8 6 2 8 7 2 8 8 2 8 9 2 9 3 2 9 4 2 9 5 2 9 6 2 9 7 2 9 8 2 9 9 3 3 3 4 3 3 5 3 3 6 3 3 7 3 3 8 3 3 9 3 4 4 3 4 5 3 4 6 3 4 7 3 4 8 3 4 9 3 5 4 3 5 5 3 5 6 3 5 7 3 5 8 3 5 9 3 6 4 3 6 5 3 6 6 3 6 7 3 6 8 3 6 9 3 7 4 3 7 5 3 7 6 3 7 7 3 7 8 3 7 9 3 8 4 3 8 5 3 8 6 3 8 7 3 8 8 3 8 9 3 9 4 3 9 5 3 9 6 3 9 7 3 9 8 3 9 9 4 4 4 5 4 4 6 4 4 7 4 4 8 4 4 9 4 5 5 4 5 6 4 5 7 4 5 8 4 5 9 4 6 5 4 6 6 4 6 7 4 6 8 4 6 9 4 7 5 4 7 6 4 7 7 4 7 8 4 7 9 4 8 5 4 8 6 4 8 7 4 8 8 4 8 9 4 9 5 4 9 6 4 9 7 4 9 8 4 9 9 5 5 5 6 5 5 7 5 5 8 5 5 9 5 6 6 5 6 7 5 6 8 5 6 9 5 7 6 5 7 7 5 7 8 5 7 9 5 8 6 5 8 7 5 8 8 5 8 9 5 9 6 5 9 7 5 9 8 5 9 9 6 6 6 7 6 6 8 6 6 9 6 7 7 6 7 8 6 7 9 6 8 7 6 8 8 6 8 9 6 9 7 6 9 8 6 9 9 7 7 7 8 7 7 9 7 8 8 7 8 9 7 9 8 7 9 9 8 8 8 9 8 9 9 9 (0 0)
Table
The table below shows a more structured version of the sequence:
0
0 0 1
0 0 2
0 0 3
0 0 4
0 0 5
0 0 6
0 0 7
0 0 8
0 0 9
0 1 1
0 1 2
0 1 3
0 1 4
0 1 5
0 1 6
0 1 7
0 1 8
0 1 9
0 2 1
0 2 2
0 2 3
0 2 4
0 2 5
0 2 6
0 2 7
0 2 8
0 2 9
0 3 1
0 3 2
0 3 3
0 3 4
0 3 5
0 3 6
0 3 7
0 3 8
0 3 9
0 4 1
0 4 2
0 4 3
0 4 4
0 4 5
0 4 6
0 4 7
0 4 8
0 4 9
0 5 1
0 5 2
0 5 3
0 5 4
0 5 5
0 5 6
0 5 7
0 5 8
0 5 9
0 6 1
0 6 2
0 6 3
0 6 4
0 6 5
0 6 6
0 6 7
0 6 8
0 6 9
0 7 1
0 7 2
0 7 3
0 7 4
0 7 5
0 7 6
0 7 7
0 7 8
0 7 9
0 8 1
0 8 2
0 8 3
0 8 4
0 8 5
0 8 6
0 8 7
0 8 8
0 8 9
0 9 1
0 9 2
0 9 3
0 9 4
0 9 5
0 9 6
0 9 7
0 9 8
0 9 9
1
1 1 2
1 1 3
1 1 4
1 1 5
1 1 6
1 1 7
1 1 8
1 1 9
1 2 2
1 2 3
1 2 4
1 2 5
1 2 6
1 2 7
1 2 8
1 2 9
1 3 2
1 3 3
1 3 4
1 3 5
1 3 6
1 3 7
1 3 8
1 3 9
1 4 2
1 4 3
1 4 4
1 4 5
1 4 6
1 4 7
1 4 8
1 4 9
1 5 2
1 5 3
1 5 4
1 5 5
1 5 6
1 5 7
1 5 8
1 5 9
1 6 2
1 6 3
1 6 4
1 6 5
1 6 6
1 6 7
1 6 8
1 6 9
1 7 2
1 7 3
1 7 4
1 7 5
1 7 6
1 7 7
1 7 8
1 7 9
1 8 2
1 8 3
1 8 4
1 8 5
1 8 6
1 8 7
1 8 8
1 8 9
1 9 2
1 9 3
1 9 4
1 9 5
1 9 6
1 9 7
1 9 8
1 9 9
2
2 2 3
2 2 4
2 2 5
2 2 6
2 2 7
2 2 8
2 2 9
2 3 3
2 3 4
2 3 5
2 3 6
2 3 7
2 3 8
2 3 9
2 4 3
2 4 4
2 4 5
2 4 6
2 4 7
2 4 8
2 4 9
2 5 3
2 5 4
2 5 5
2 5 6
2 5 7
2 5 8
2 5 9
2 6 3
2 6 4
2 6 5
2 6 6
2 6 7
2 6 8
2 6 9
2 7 3
2 7 4
2 7 5
2 7 6
2 7 7
2 7 8
2 7 9
2 8 3
2 8 4
2 8 5
2 8 6
2 8 7
2 8 8
2 8 9
2 9 3
2 9 4
2 9 5
2 9 6
2 9 7
2 9 8
2 9 9
3
3 3 4
3 3 5
3 3 6
3 3 7
3 3 8
3 3 9
3 4 4
3 4 5
3 4 6
3 4 7
3 4 8
3 4 9
3 5 4
3 5 5
3 5 6
3 5 7
3 5 8
3 5 9
3 6 4
3 6 5
3 6 6
3 6 7
3 6 8
3 6 9
3 7 4
3 7 5
3 7 6
3 7 7
3 7 8
3 7 9
3 8 4
3 8 5
3 8 6
3 8 7
3 8 8
3 8 9
3 9 4
3 9 5
3 9 6
3 9 7
3 9 8
3 9 9
4
4 4 5
4 4 6
4 4 7
4 4 8
4 4 9
4 5 5
4 5 6
4 5 7
4 5 8
4 5 9
4 6 5
4 6 6
4 6 7
4 6 8
4 6 9
4 7 5
4 7 6
4 7 7
4 7 8
4 7 9
4 8 5
4 8 6
4 8 7
4 8 8
4 8 9
4 9 5
4 9 6
4 9 7
4 9 8
4 9 9
5
5 5 6
5 5 7
5 5 8
5 5 9
5 6 6
5 6 7
5 6 8
5 6 9
5 7 6
5 7 7
5 7 8
5 7 9
5 8 6
5 8 7
5 8 8
5 8 9
5 9 6
5 9 7
5 9 8
5 9 9
6
6 6 7
6 6 8
6 6 9
6 7 7
6 7 8
6 7 9
6 8 7
6 8 8
6 8 9
6 9 7
6 9 8
6 9 9
7
7 7 8
7 7 9
7 8 8
7 8 9
7 9 8
7 9 9
8
8 8 9
8 9 9
9
Example: A de Bruijn sequence with k=10 and n=4 is a minimal sequence to type 
for testing all the possible (code) sequences of length 4 on a device with 
10 keys (labelled 0 to 9), and there are no restriction that you have to 
type Enter after each try. Click here to see that sequence. See the URL:s below for somewhat more serious applications...
For more information about these types of sequences see e.g.
The code/algortihm for this program is from the inspirational Combinatorial 
Object Server, COS, at http://theory.cs.uvic.ca/~cos/.
See also: 
 -  de Bruijn Applet, a Java Applet using the same approach as this program
 
-  de Bruijn arbitrary sequences which generates sequences of "arbitrary" length
 
-  de_bruijn.frink: implementation in the programming language Frink (se my Frink page for more info about the language)
 -  de_bruijn2.frink: implementation in the programming language Frink, similar to de_bruijn.frink but using OOP (and some extra features).
 
-  debruijn.html, code: debruijn.js: implementation in JavaScript, 
 
-  debruijn.icn: implementation in Icon/Unicon
 
-  There is also a couple of other implementations using Constraint Programming which makes it possible to generate all possible solutions for a configuration (i.e. some specific nandk). These implements both the "standard" version and also the "arbitrary" variant, where the length of the sequence can be specified.
 Some of these models where discussed in the blog post de Bruijn sequences in Gecode (and other systems). (Implementing de Bruijn sequences is a standard problem when I try out a new Constraint Programming system.)
    -  debruijn_binary.mzn, a model in MiniZinc Constraint Programming language.
    
-  debruijn_binary.zinc, a model in Zinc Constraint Programming language (a superset of the MiniZinc system).
    
-  de_bruijn.pi, implemented in Picat
    
-  DeBruijn.java, a model in JaCoP, (a Java based) constraint programming language 
    
-  DeBruijn.scala a model in JaCoP/Scala
    
-  DeBruijn.java, a model in Choco constraint programming language (Java)
   
-  debruijn_binary.rb, a model in Gecode/R constraint programming language (Ruby interface to Gecode)
    
-  debruijn.co, a model in Comet another constraint programming language
    
-  debruijn.cpp, a model in Gecode a constraint programming language in C++
    
-  debruijn.ecl, a model in ECLiPSe Constraint Logic Programming language
    
-  debruijn_binary.py using Google or-tools Python interface
    
-  DeBruijn.java using Google or-tools Java interface
    
-  debruijn.cs using Google or-tools C# interface
    
-  debruijn.pl, a model in SICStus Constraint Logic Programming language
    
-  debruijn.eprime, a model in Tailor/Essence' Constraint Programming system
    
-  DeBruijn.scala, a model in OscaR Constraint Programming system (based on Scala)
    
-  debruijn_binary.py, implemented in z3/Py
    
-  de_bruijn.pl, in SWI-Prolog
  
-  Related: 2D de Bruijn torus/matrices in MiniZinc:
    
 
Back to my homepage
Created by Hakan Kjellerstrand hakank@gmail.com