Problem 3. Parameter Passing Consider the following block. Assume dynamic scoping. 1 ( int y; 2 int z; 3 4 e 5 6 7 8 e 9 10 11 12 13 14 15 }; y := 6; { int }; f(int a) { y = a +1; return (y+a) }; int g(int x) { y = f(x+1)+2; z = f(x-y+2); return (z+1) } z = g(y*2); a) Draw the runtime stack after each line executes given that both parameters a and x are passed using Call-by-Name. What are the values of y and z after line 13 executes? b) Draw the runtime stack after each line executes given that both parameters a and x are passed using Call-by-Need. What are the values of y and z after line 13 executes?

Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
icon
Related questions
Question
Problem 3. Parameter Passing
Consider the following block. Assume dynamic scoping.
1 = {
2
3
4 e
5
LO
01
7
8
9
10
11
12
13
14
15
};
int y;
int z;
y = 6;
{ int f(int a) {
};
y := a+1;
return (y+a)
};
int g(int x) {
y = f(x+1)+2;
z = f(x-y+2);
return (z+1)
}
Z := g(y*2);
a) Draw the runtime stack after each line executes given that both parameters a and x are passed
using Call-by-Name. What are the values of y and z after line 13 executes?
b) Draw the runtime stack after each line executes given that both parameters a and x are passed
using Call-by-Need. What are the values of y and z after line 13 executes?
Transcribed Image Text:Problem 3. Parameter Passing Consider the following block. Assume dynamic scoping. 1 = { 2 3 4 e 5 LO 01 7 8 9 10 11 12 13 14 15 }; int y; int z; y = 6; { int f(int a) { }; y := a+1; return (y+a) }; int g(int x) { y = f(x+1)+2; z = f(x-y+2); return (z+1) } Z := g(y*2); a) Draw the runtime stack after each line executes given that both parameters a and x are passed using Call-by-Name. What are the values of y and z after line 13 executes? b) Draw the runtime stack after each line executes given that both parameters a and x are passed using Call-by-Need. What are the values of y and z after line 13 executes?
Expert Solution
trending now

Trending now

This is a popular solution!

steps

Step by step

Solved in 3 steps

Blurred answer
Knowledge Booster
ADT and Class
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Similar questions
Recommended textbooks for you
Database System Concepts
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education