Lab Session #4 #
Agenda #
- Recap: Pumping lemma
- Exercises
Pumping lemma #
In the theory of formal languages, the pumping lemma for regular languages is a lemma that describes an essential property of all regular languages. Informally, it says that all sufficiently long strings in a regular language may be pumped—that is, have a middle section of the string repeated an arbitrary number of times—to produce a new string that is also part of the language.The pumping lemma is stated as follows:
Given a regular language there exists an integer (critical length) such that for any string with length we can find a split such that:
- for all
The pumping lemma can be used to prove that a language is not regular by finding a string in the language that does not satisfy the pumping lemma. For example, the language of all strings that are balanced parentheses is not regular. The string “(()” can be pumped to produce the strings “()()” and “(())”, but the latter string is not balanced.
The pumping lemma is a powerful tool for proving that a language is not regular. However, it is important to note that the pumping lemma does not prove that a language is regular. A language that satisfies the pumping lemma may still be irregular.
Here are some examples of regular languages:
- The language of all strings of 0s and 1s
- The language of all strings of lowercase letters
- The language of all strings of uppercase letters
- The language of all strings of digits
Here are some examples of languages that are not regular:
- The language of all strings that are balanced parentheses
- The language of all strings that are palindromes
- The language of all strings that are prime numbers
The pumping lemma is a useful tool for understanding the structure of regular languages. It can be used to prove that a language is not regular, and it can also be used to help design regular expressions.
Pumping lemma: contrapositive #
The contrapositive of a statement is the statement that reverses and negates both the hypothesis and the conclusion. In other words, the contrapositive of a statement is true if and only if the negation of the conclusion is true.
Given a language
. If we show that
for any integer
there exists a string
such that
and for all possible splits
with
- \
there exists:
such that
.
Then, applying the Pumping lemma for regular languages, one can
deduce that
is not regular.
Exercises #
Using Pumping lemma prove that and are not regular languages:
- where
Solution:
Let’s take an arbitrary integer .
Let
.
Split in the form : as and , , .
Let’s look at . It will have the form .
As .
We have shown that for any we can find , such that and for all with and and there exists such that .
So, applying Pumping lemma we can deduce that is not regular.
- has an equal number of ’s and ’s over
Solution:
Let’s take an arbitrary integer .
Let
.
Split in the form : as and , , .
Let’s look at . It will have the form . As , .
We have shown that for any we can find , such that and for all with and and there exists such that .
So, applying Pumping lemma we can deduce that is not regular.
- over
Solution:
Let’s take an arbitrary integer .
Let
.
Split in the form : as and , , .
Let’s look at . It will have the form .
As .
As .
By algebra, , as
So for we get that , which means that there is no such that , so
For so , and the string Applying Pumping lemma we can deduce that is not regular.
for
- over
Solution:
Let’s take an arbitrary integer .
Let
.
Split in the form : as and , , .
Let’s look at . It will have the form .
As , applying Pumping lemma we can deduce that is not regular.