| Question   | Answer   | 
        
        |  start learning What are the components of a language  |  |   Lexical Structures, Syntax, Semantics  |  |  | 
|  start learning What is meant by lexical Structures  |  |   Its lexical structures, which concerns the forms of its individual symbols (e.g.:=), keywords, identifiers etc.  |  |  | 
| start learning |  |   Its syntax, which define the structure of the components of the language, e.g., the structures of programs, statements (e.g., assignment), expression, terms etc.  |  |  | 
|  start learning What is meant by semantics  |  |   Its semantics, which define the meanings and usage of structures and requirements that cannot be describe by a grammar.  |  |  | 
|  start learning Language analysis constist of what 2 parts?  |  |   [1] A low-level part called a lexical analyzer (mathematically, a finite automaton based on a regular grammar) [2] A high-level part called a syntax analyzer, or parser (mathematically, a push-down automaton based on a context-free grammar)  |  |  | 
| start learning |  |   A lexical analyser (scanner) reads the source program, a character at a time, and outputs tokens to the next phase of the compiler (parser)  |  |  | 
|  start learning What does a lexical anayser do?  |  |   [1] It identifies substrings of the source program that belong together - lexemes [2] Lexemes match character patterns, which are associated with a lexical category called a token [3] sum is a lexeme; its token may be IDENT  |  |  | 
| start learning |  |  |  |  | 
| start learning |  |   deterministic finite automata  |  |  | 
| start learning |  |   deterministic finite automata (DFAs), which can be used to implement a pattern matching process;  |  |  | 
|  start learning What is the definition of Alphabet  |  |   [1] An alphabet Σ is a finite non-empty set(of symbols) eg:[2] set Σab={a, b} is an alphabet comprising symbols a and b; [3] the set Σaz = {a, ..., z} is the alphabet of lowercase English letters; [4] the set Σasc of all ASCII characters is an alphabet.  |  |  | 
|  start learning What is the definition of Strings  |  |   [1] A string or word over an alphabet Σ is a finite concatenation (or juxtaposition) of symbols from Σ. [2] abba, aaa and baaaa are strings over Σab; [3] hello, abacab, and baaaa are strings over Σaz; [4] h$(e′lo, PjM#;, and baaaa are strings over Σasc.  |  |  | 
|  start learning How are the lengths of Strings denoted?  |  |   [1] The length of a string w (that is, the number of symbols it has) is denoted |w|. E.g., |abba| = 4. [2] The empty or null string is denoted ε, and so |ε| = 0.  |  |  | 
|  start learning What isThe set of all strings over Σ  |  |   Σ∗ab = {ε, a, b, aa, ab, ba, bb, aab,...}.  |  |  | 
|  start learning How is the concatenation of a string denoted?  |  |   For any symbol or string x, xn denotes the string of the concatenation of n copies of x. E.g. a4 = aaaa (ab)4 = abababab  |  |  | 
|  start learning Regular expressions s__ p___ of strings of symbols  |  |   Regular expressions specify patterns of strings of symbols  |  |  | 
|  start learning Regular expressions ___ ____ of strings of ___  |  |   Regular expressions specify patterns of strings of symbols  |  |  | 
|  start learning How is the set of Strings matched by RE r denoted?  |  |   The set of strings matched by a RE r is denoted L(r) ⊆ Σ∗ (all the strings over the alphabet Σ) and is called the language determined or generated by r  |  |  | 
|  start learning When does a regular expression match a set of strings?  |  |   We say a regular expression r matches (or is matched by) a set of strings if the patterns of the strings are those specified by the regular expression.  |  |  | 
|  start learning What is the regular expression ∅  |  |   ∅ (the symbol for empty-set or empty language, i.e., the set contains nothing) is a regular expression. This RE matches no strings at all  |  |  | 
|  start learning what is the regualr expression ε  |  |   ε (the empty string symbol) is a regular expression. This matches just the empty string ε.  |  |  | 
|  start learning what does this mean "Each symbol c ∈ Σ in the alphabet Σ i".  |  |   This RE matches the string consisting of just the symbol c.  |  |  | 
|  start learning explain in words Σ = {a, b}  |  |   [1] a which matches the string a; and [2] b which matches the string b, [3] Both symbols a and b are REs.  |  |  | 
|  start learning If r and s are regular expressions is r | s a regualr expression?  |  |  |  |  | 
|  start learning what are the otehr wars to write r | s  |  |   r + s, and read “r or s”)  |  |  | 
| start learning |  |   Regular expression a | b matches the strings a or b.  |  |  | 
|  start learning If r and s are regular expressions waht is the concatenation of r and s?  |  |   rs(read “r followed by s”)  |  |  | 
|  start learning can brackets be used in regular expressions?  |  |   yes, As with arithmetic expressions, parentheses can be used in REs to make the meaning of a regular expression clear.  |  |  | 
|  start learning is r* a regular expression?  |  |   yes (read “zero or more instances of r”)  |  |  | 
| start learning |  |   r∗ (read “zero or more instances of r”) is a RE. This matches all finite (possibly empty) concatenations of strings matched by r.  |  |  | 
| start learning |  |   rr∗ (one or more copies of strings matched by r)  |  |  | 
| start learning |  |   r^+ (the ^ is her only for computer on paper its just r to the plus)  |  |  | 
|  start learning What does the Regular expression a∗ matches  |  |   strings ε, a, aa, aaa,...  |  |  | 
| start learning |  |   the strings ε, ab, abab,...  |  |  | 
|  start learning what does RE (a|bb)∗ match  |  |   the strings ε, a, bb, abb, bba, abba,...  |  |  | 
|  start learning what does RE (a|b)∗aab match  |  |   any string ending with aab  |  |  | 
|  start learning What does RE (a|b)∗baa(a|b)∗ match  |  |   any string containing the substring bba.  |  |  | 
|  start learning What is the precedence order for regular expressions  |  |   [1]() has the highest precedence; [2] then ∗ (or +); [3] then concatenation; and [4] | has lowest precedence.  |  |  | 
|  start learning how are REs used for Lexical Analysis  |  |   Regular expressions provide us with a way to describe the patterns of a programming language.  |  |  | 
|  start learning assuming the alphabet is Σasc (the set of all ASCII characters) what is a typical programs pattern(regular expression) for an IF;  |  |  |  |  | 
|  start learning assuming the alphabet is Σasc (the set of all ASCII characters) what is a typical programs pattern(regular expression) for a;  |  |  |  |  | 
|  start learning assuming the alphabet is Σasc (the set of all ASCII characters) what is a typical programs pattern(regular expression) for (0|1|2|3|4|5|6|7|8|9)+  |  |   (0|1|2|3|4|5|6|7|8|9)+ for a token NUMBER;  |  |  | 
|  start learning assuming the alphabet is Σasc (the set of all ASCII characters) what is a typical programs pattern(regular expression) for (a|...|z|A|···|Z)(_|a|...|z|A|···|Z|0|···|9)∗  |  |   (a|...|z|A|···|Z)(_|a|...|z|A|···|Z|0|···|9)∗ for a token IDENT.  |  |  | 
|  start learning We can give REs ____ which make REs more easy to read and write, and can be used to define other regular definitions.  |  |   We can give REs names, which make REs more easy to read and write, and can be used to define other regular definitions.  |  |  | 
|  start learning what are some examples of named regualr expressions  |  |   [1] letter = A | B |···|Z | a | b |···| z [2] digit = 0 | 1 | ··· | 9 [3] ident=letter (_| letter | digit)∗  |  |  | 
|  start learning what is the formal lexical definition of a language  |  |   A language L over an alphabet Σ is a subset of Σ∗ (i.e. L ⊆ Σ∗).  |  |  | 
|  start learning using the lexical definition fo a language what is {ε, aab, bb}  |  |   {ε, aab, bb} is a language over Σab;  |  |  | 
|  start learning using the lexical definition fo a language what is the set of all Java programs  |  |   the set of all Java programs is a language over Σasc;  |  |  | 
|  start learning using the lexical definition fo a language what is ∅  |  |   ∅ is the empty language (over any alphabet) with no strings;  |  |  | 
|  start learning using the lexical definition fo a language what is {ε}  |  |   {ε} is a language (over any alphabet) containing just the empty string.  |  |  | 
|  start learning using the lexical definition fo a language what is Σ∗  |  |   Σ∗ is a language over Σ for any alphabet Σ.  |  |  | 
|  start learning How is the language of REs denoted?  |  |   L(RE) e.g. (a∗) = {ε, a, aa, aaa,...}  |  |  | 
| start learning |  |  |  |  | 
|  start learning explain a decision procedure for L  |  |   an algorithm such that a language L over some alphabet Σ is able to take any input stringw ∈ Σ∗, and: 1. outputs ‘Yes’ if w ∈ L and 2. outputs ‘No’ if w not ∈ L.  |  |  | 
|  start learning Languages that can be denoted by a RE, and can have a DFA/NFA as a decision procedure, are known as _____ ______.  |  |   Languages that can be denoted by a RE, and can have a DFA/NFA as a decision procedure, are known as regular languages.  |  |  | 
|  start learning Study has shown that we can write a decision procedure for language L(r) using one of the what 2 algorithms?  |  |   [1] a Deterministic Finite Automaton (DFA), or [2] a Nondeterministic Finite Automaton (NFA).  |  |  | 
|  start learning What is Nondeterministic Finite Automaton (NFA).  |  |   An NFA is a Nondeterministic Finite Automaton. Nondeterministic means it can transition to, and be in, multiple states at once (i.e. for some given input).  |  |  | 
|  start learning what is a Deterministic Finite Automaton (DFA),  |  |   A DFA is a Deterministic Finite Automaton. Deterministic means that it can only be in, and transition to, one state at a time (i.e. for some given input).  |  |  |