A simple game to help you understand the pumping lemma for regular languages.

Exercise: | Random |

Here we go: The computer claims that the language $L$ over the alphabet $\Sigma$ is regular. It also claims it can build a finite automaton accepting $L$ using $n$ states.

It's your turn now. Please enter a word belonging to $L$ that's at least $n$ characters long, then press the "Continue" button.

Now use the sliders to highlight a part of the string that's at least $n$ characters long, then press the "Continue" button. (The computer will pick a substring of what you've highlighted.)

to | ||

This is the computer's pick:

You can now change how often this pick appears in the string. Your job of course is to end up with a string that does *not* belong to the language.

Do the same language again (maybe even with the same number of states) or randomly select another language.

When you're entering your initial word, you can type something like, say, `a5`

as a shorthand for `aaaaa`

. More complicated expressions like `(a3b5)2`

will also work as expected. Characters other than `a`

and `b`

(including whitespace) will simply be ignored.

Note that some of the languages presented here *are* regular
and the computer should always win in these cases. It is part of
your task to figure out which are which...

And please also note that above zero is always a natural number and all variables like $m$ or $n$ are implicitly understood to be natural numbers. Finally, $w^{\mathtt{R}}$ is the word $w$ reversed.

Copyright (c) 2014, Prof. Dr. Edmund Weitz