Lista Unidade 1
Lista Unidade 1
Lista Unidade 1
PARADIGMAS DE LINGUAGENS I
LISTA DE EXERCCIOS
UNIDADE 1
01) Conceitue Linguagem de Programao e diferencie Sintaxe de Semntica.
02) Apresente 2 exemplos de erro sinttico e 2 exemplos de erro semntico que podem ser
cometidos durante a programao.
03) Descreva e justifique pelo menos trs critrios (ou questes) importantes que devem
considerados no momento da escolha de qual LP ser utilizada.
04) Diferencie amarrao esttica de dinmica.
05) Construa o diagrama de sintaxe para a seguinte gramtica expressa em EBNF:
<goal> :: = <expression1>
<expression1> ::= <term1> <expression2>
*
<expression2> ::= + <expression1>
<term1> ::= <factor> <term2>
*
<term2> ::= * <term1>
<factor> ::= a | b | c | (<expression1> )
06) Considerando a seguinte gramtica
<goal> :: = <group2>
+
d
*
e
<group2> :: = <group1>
*
c
<group1> :: = ab
determine quais das sentenas abaixo so vlidas:
a) abcde
b) ce
c) abe
d) ababce
e) ccee
f) dddde
g) cddd
h)aabbce
i) e
07) Adicione subtrao e diviso, determinando a precedncia apropriada, gramtica EBNF
descrita a seguir e construa o seu diagrama de sintaxe.
<exp> :: = <term> <op1>
*
<op1> ::= + <term>
<term> ::= <factor> <op2>
*
<op2> ::= * <factor>
<factor> ::= ( <exp> ) | <number>
<number> ::= <digit> <digit>
*
<digit> ::= 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9
08) Usando a gramtica do exerccio anterior, construa a rvore de derivao para a seguinte
expresso aritmtica: 3*(4-5) / (6+7)
09) Escreva uma gramtica BNF ou EBNF e um diagrama de sintaxe para a linguagem composta
por nmeros binrios que deve conter pelo menos dois 0s consecutivos (a linguagem inclui os
strings 10011011010 e 100010, mas no 01011010101).
2
10) Escreva as seguintes expresses utilizando notao pr-fixada: 2 + 6 * 5 - 8 e 9 / 3 + 7 * 4
11) Escreva as seguintes expresses utilizando notao ps-fixada: 2 + 6 * 5 - 8 e 9 / 3 + 7 * 4
12) O que uma exceo ? D um exemplo.
13) Qual a diferena entre um compilador e um interpretador?
14) Considere o fragmento de cdigo em Pascal apresentado a seguir e indique na tabela as
atribuies legais, de acordo com a equivalncia de tipos, e o tipo de equivalncia entre os dois
lados dos comandos de atribuio.
type t1 = 1..20
t2 = 5..10
range = 1..10
ar = array [range] of boolean
t3 = record
f1: boolean;
f2: integer;
end;
t4 = record
f1: boolean;
f2: integer;
end;
rec1 = record
x: boolean;
y: integer;
z: ar;
end;
rec2 = record
x: boolean;
y: integer;
z: = array [1..10] of boolean;
end;
rec3 = record
x: integer;
y: boolean;
z: = ar;
end;
var a, b: t1;
c: integer;
d: t2;
e: 1..5;
f, g: t3;
h, i: t4;
j: rec1;
k: rec2;
l: rec3;
Estrutural Nominal
a:=b;
i:=a;
d:=e;
f.f2:=c;
f:=g;
h:=g;
i:=h;
j=k;
j=l;
3
15) No programa apresentado abaixo, faa um diagrama para apresentar o escopo de cada
varivel declarada (a, b, e c):
program Escopo;
var a, b, c: integer;
procedure P1;
var a, c: integer;
procedure P2;
var a: real;
begin
a := 4;
end;
begin
a := 1;
c := 9;
end;
procedure P3;
var b: integer;
begin
b := 6;
end;
begin
a := 3;
b := 0;
c := 8;
end;
16) Considere o programa exemplo apresentado a seguir. Diga o que acontece se a passagem
de parmetro para swap(a[i], a[j]) for por referncia, por valor e por valor-resultado. O que
acontece se i for igual a j?
swap (int x, int y)
{
x = x + y;
y = x y;
x = x y;
}
17) Considere o programa exemplo apresentado a seguir. Diga o que acontece se a chamada
do procedimento for intswap(i, a[i]) e a passagem de parmetro por nome for usada para os
parmetros x e y.
procedure intswap (x, y: integer)
var t: integer;
begin
t := x;
x := y;
y := t;
end
4
18) Considere o seguinte exemplo de programa, escrito em uma linguagem semelhante ao
ALGOL, cuja passagem de parmetro feita por nome. Diga o que contm o vetor "LIST"
aps a execuo do programa.
procedure BIGSUB;
integer GLOBAL;
integer array LIST[1:2];
procedure SUB (PARAM);
integer PARAM;
begin
PARAM := 5;
GLOBAL := GLOBAL * 2;
PARAM := 10
end;
begin
LIST[1] := 2;
LIST[2] := 2;
GLOBAL := 1;
SUB (LIST[GLOBAL])
end;
19) Construa o diagrama de sintaxe para a seguinte gramtica BNF de uma pequena
linguagem de programao:
<programa> :: = begin <lista_stmt> end
<lista_stmt> ::= <stmt> | <stmt> ; <lista_stmt>
<stmt> ::= <var> := <expresso>
<var> ::= A | B | C
<expresso> ::= <var> + <var> | <var> - <var> | <var>
20) Usando a gramtica do exerccio anterior, construa a rvore de derivao para a seguinte
expresso:
begin A := B + C ; B := C end