Getting Started
Start a terminal. Create a lab directory and download JFLAP:
cd $HOME
mkdir -p CS340/CS340_Lab02
cd CS340/CS340_Lab02
wget http://ycpcs.github.io/cs340-fall2014/resources/JFLAP.jar
Start JFLAP:
java -jar JFLAP.jar
As you create automata in JFLAP, save them (as .jff files) in the CS340/CS340_Lab02 directory.
Your Task
In JFLAP, implement finite automata for the following four regular languages.
You should execute your finite automata on example input strings. Make sure that the automata accept the example strings which are in the language, and reject the example strings which are not in the language.
Languages 1-3 use the alphabet {a, b}. Language 4 uses the alphabet {a, b, c}.
Language 1
The first language contains strings starting with aa, followed by 0 or more b's, and ending with a.
Example strings which are in the language:
aaa
aaba
aabba
aabbba
aabbbba
Example strings which are not in the language:
aa
aabaa
baaa
aaab
aba
Language 2
The second language contains strings which do not start with ba.
Example strings which are in the language:
ε (the empty string)
a
b
aa
bb
bba
Example strings which are not in the language:
ba
baa
bab
baba
Language 3
The third language contains strings which have an even number of a's.
Example strings which are in the language:
ε (the empty string)
b
bbb
baba
aababba
baa
baabaa
Example strings which are not in the language:
a
bab
aaba
bbbabb
Language 4
The fourth language contains all strings (over the alphabet {a, b, c}) that do not contain the substring bc.
Avoiding the generation of a substring using a regular expression is difficult. However, matching a substring (and not accepting strings that contain it) using a regular expression is pretty easy!
Example strings which are in the language:
ε (the empty string)
abac
abb
bac
bacca
Example strings which are not in the language:
bc
bca
bcb
bcc
abc
bbabca