Next: About this document ...
Up: Quiz3
Previous: Exercise 2.
Translate the following MOOL piece of code into three-address code.
while not (a = b) repeat {
if (a < b) then {
b := b - a;
} else {
a := a - b;
};
};
The three-address code instructions you may need are of one of the forms:
- goto L where L is a symbolic label (like L1, L2, ...)
- if x relop y goto L where relop can be = or <
- x:= y op z where op can be -
Moreover your solution does not need to be obtained by one of the
algorithms of the course.
Just consider that you are programming a very basic calculator.
Answer 3
data:image/s3,"s3://crabby-images/c8b2d/c8b2dc86d159393dbff6da74c73f480761a169b3" alt="\fbox{
\begin{minipage}{13 cm}
\begin{center}
\begin{tabular}{ll}
L1 & {\tt if a...
...- b } \\
L4 & {\tt goto L1 } \\
L5 &
\end{tabular}\end{center}\end{minipage}}"
Next: About this document ...
Up: Quiz3
Previous: Exercise 2.
Marc Moreno Maza
2004-12-02