Scanning, LL Parsing, LR Parsing Flashcards
What do the following mean with regards to regular expressions:
- Token
- Alphabet
- Epsilon
data:image/s3,"s3://crabby-images/42d1f/42d1f2225e5a412a6904804e868d0a9691255f5a" alt=""
The arrow in regular expressions means?
Can be
What is the precedence order for the following in regular expressions:
|
.
*
data:image/s3,"s3://crabby-images/056bd/056bd822bba794d466f700a62ff3bae8f2b5ea6b" alt=""
What is a CFG?
A CFG is a Context Free Grammar
data:image/s3,"s3://crabby-images/827d7/827d72a34070ee86be3a9a0b45e9b35622ad02b8" alt=""
What is a CFG derivation?
A production from a CFG, what can be replaced in the LHS of a sentence (non-terminals) with RHS non-terminals and terminals as productions.
Note in the following example how expr is replaced
data:image/s3,"s3://crabby-images/7aec5/7aec5938668b124bd6913623b8906efe9b0fcfa2" alt=""
What does a parse tree do?
Represents a derivation graphically
What is the difference between right-most derivation and left-most derivation?
data:image/s3,"s3://crabby-images/2ada6/2ada6c7d3145c59d2661265b8c6167b59284f90a" alt=""
When a grammar can have two parse trees for the same sentence, what is it called?
Ambiguous grammar
What is an ambiguous grammar?
When there can be two difference parse trees for the same grammar
What is lexical analysis
Scanning:
Tokenizing the source code
Removing comments
Saving text of identifiers, numbers, strings
Saving source locations
What is ad-hoc
Ad-hoc simply means it was created by a human for the specific purpose of what it is being used for
What is a DFA? What does it mean? What do they look like?
A DFA is a deterministic finite automaton which means each state goes to one other state based on its current state and input.
data:image/s3,"s3://crabby-images/6665c/6665ca7f1f9128a29c77e9313ffd5e330c684c6a" alt=""
What is a NFA? What do they look like?
data:image/s3,"s3://crabby-images/f925e/f925e5074af5a9bab8e0b06cf7a67052089fd606" alt=""
How do you construct DFA from regular expressions?
Build NFA from regular expressions
Convert to DFA
Minimize DFA
Examine this NFA example:
data:image/s3,"s3://crabby-images/7d2f2/7d2f20921c3d341845f2c650ad6ee0f3753d7d4c" alt=""
Examine the following example for minimizing an NFA to DFA, dont move on until you understand
data:image/s3,"s3://crabby-images/94f15/94f154bdcf260f569d55662bd7f9182b66d644d7" alt=""
What is the “longest-possible token” rule?
Return only when the next character cannot continue the current token
What is look-ahead?
How many characters you need to look forward to deterine the production being used
Examine the following table-driven scanner:
data:image/s3,"s3://crabby-images/ac21b/ac21b13224dbe3d61705b7155856db0e340583ef" alt=""
What is parsing?
data:image/s3,"s3://crabby-images/5834d/5834db90788eb56753dc8d0955f40fce643f242c" alt=""
What is the difference between LL and LR parsing?
data:image/s3,"s3://crabby-images/381c8/381c8d81d962895a125f2d9d12f23a92d78ab38f" alt=""
Is LL parsing top-down or bottom-up?
Top-down
Is LR parsing top-down or bottom-up
Bottom-up
Top-down parsers are also called ____, the employ _____
Top-down parsers are also called LL parsers, the employ recursive descent
LL / top-down parsers are ____ ____
Table driven
A prediction in L parsing is based on
The current state and the input token
With a current state and a given input token, a LL parser can take the following actions:
- match a terminal
- predict a production
- Announce a syntax error
Examine the following LL(1) parse table and understand what it means FULLY
data:image/s3,"s3://crabby-images/2f56a/2f56a82a430862f301f4e72a063df3799de9f8e4" alt=""
Review the following LL(1) parse stack and how it works
data:image/s3,"s3://crabby-images/7627f/7627f3fd7ec9af629f1e7781a07b94d44f103a42" alt=""
How do you construct First(a) and Follow(A)?
data:image/s3,"s3://crabby-images/a1677/a1677a823e4cccb13bec98779c9a2534069af2e0" alt=""
What are some common problems with making a grammar LL(1)? What are their fixes?
data:image/s3,"s3://crabby-images/86ae5/86ae59eac55a1c1706f3fde9d6c62cb9d302b859" alt=""
Is there a LL(1) grammar for the dangling-else problem?
NO
What is the premise of an LR parser?
Read from input until you find a RHS, continue until you have fully reduced
data:image/s3,"s3://crabby-images/31a12/31a12f02d10f95f79f53ab90548e47bc685debd2" alt=""
Examine how the dot productions work with LR parsing:
data:image/s3,"s3://crabby-images/074ad/074ad83aec1e46a78cf8b004b380654a244cc9e3" alt=""
Examine the following LR parse table:
data:image/s3,"s3://crabby-images/88294/88294d90d345b6c56e618fefd57b7d5ac6541d39" alt=""
Examine the following parse table:
data:image/s3,"s3://crabby-images/78912/789129e082ed770db1f73282bcf71386a4f937b4" alt=""
Examine the following LR parse stack
data:image/s3,"s3://crabby-images/7d815/7d8158ba025b15a41ee02e3caa2a18fcf654853a" alt=""
What is a shift/reduce conflict?
data:image/s3,"s3://crabby-images/17e42/17e42f711e6f0c85318f8d96f9546baef2af48aa" alt=""
What are two SLR conflicts?
data:image/s3,"s3://crabby-images/527da/527da381826bee59c9d9ded68d085f8aa54fdcec" alt=""
Examine the following for LL Left-recursion elimination:
data:image/s3,"s3://crabby-images/6aafa/6aafa2a96a2d52e5ca028eefa6cccea3d99fab13" alt=""