Recibo, 2ª frequência, 1ºsemestre, 1998/99, Programação I :

Nome: _______________________________________________
Nº ______________________
Ass. Docente: ________________________________________


Identificação

Nome: _______________________________________________
Nº ________________
Turma: ____________


ISCTE - ETI

Introdução à Programação

2ª Frequência

1998/1999,  1º semestre


Notas:


Questão 1

Assinale com V (Verdadeiro) as expressões que estão correctas e com F (Falso) as que estão incorrectas.

Deve preencher todos os espaços indicados por um sublinhado (___) com V ou F.  Qualquer espaço não preenchido será considerado como uma resposta errada.

Qualquer alínea pode ter zero ou mais respostas correctas.  Cada resposta correctamente assinalada vale 0,5 valores.

Em todos os casos em que não é explicitamente referida a localização de uma instrução, considere que esta é dada na função main() do programa seguinte:

#include <iostream>
using namespace std;
class A {
private: 
    int x;
    int y;
public:
    int z;
    A(int a = 0);
    int f1();
    int f2(int);
    bool f3(int);
};

int main() {
    int i = 1, j = 2;
    ...
}

a)  Quais das seguintes instruções estão correctas?

__  A a = A();
__  A a;
__  A a(1);
__  A a(i,j);

 [cotação: 2]

b) Assuma que está correctamente declarada uma variável a da classe A . Quais das seguintes instruções estão correctas?

__ a.z = 1;

__ if(A::f3()) cout << "bla bla";

__ int z = a.f2(3);

 [cotação: 1.5]

c)  Assuma que as seguintes instruções são dadas dentro de uma função membro da classe A e que não são declaradas quaisquer variáveis dentro dessa função. Quais das seguintes instruções estão correctas?

__  a.x = 1;
__  A::x = 1;
__  x = 1;

 [cotação: 1.5]

 

 

 

Questão 2

2.a)  Declare uma classe Colecção que possa guardar um máximo de 100 valores do tipo inteiro (todos de valor diferente) e o número de ocorrências de cada um desses valores. Quando é inserido um valor que já se encontra na colecção apenas deve ser incrementado o número de ocorrências desse valor. Quando é inserido um valor que não existe, este passa a fazer parte da colecção e é indicado que existe apenas uma ocorrência deste valor na colecção. Não é necessário nesta alínea definir qualquer um dos métodos.

Devem existir métodos para :

Deve também ser declarada a sobrecarga do operador += que adiciona todos os elementos da colecção dada como segundo operando à colecção dada como primeiro operando (i.e., aquela que executa a operação). Deve devolver uma referência para a colecção alterada.

A classe deve também ter um construtor que possa ser invocado sem quaisquer argumentos.

A declaração da classe deve ser tal que o seguinte exemplo de utilização seja válido:

Colecção A, B;

A.insere(1);
A.insere(2);
// A = (1 [uma vez], 2 [uma vez])
B.insere(1);
B.insere(3);
// B = (1, 3)
B += A;
// B = (1 [duas vezes], 2 [uma vez], 3 [uma vez])
cout << B.ocorrências(1) << endl; // escreve 2.

 [cotação: 3]
 
 


 
 
 
 
 
 
 
 

 

 
 
 
 
 
 
 
 

2.b) Defina o construtor da classe Colecção. Este construtor deve inicializar coerentemente as variáveis de instância da classe.

[cotação: 3]
 
 
 
 
  
 
 
 

 
 
 

 

 

 

 

 

 

 

 

2.c)  Defina totalmente o método da classe Colecção que, dado um argumento inteiro, devolve o número de ocorrências do seu valor na colecção (caso esse valor não exista este método deve devolver zero).

[cotação: 3]

 

 

 

 

 

 
 
 
 
 
 

 

 

 

 

 
 2.d)  Assuma que todos os métodos declarados na classe colecção estão bem definidos, excepto o operador
+=. Defina o operador += para a classe Colecção. Esta operação adiciona todos os elementos da colecção dada como segundo operando à colecção dada como primeiro operando (i.e., aquela que executa a operação). Deve devolver uma referência para a colecção alterada (para isso use a instrução return *this).

Não esqueça que a operação insere() apenas insere uma ocorrência de um elemento. Caso um elemento ocorra N vezes numa colecção e M vezes noutra, o número total de ocorrências desse elemento na colecção devolvida deve ser M+N.

Assuma como pré-condição que há espaço para todos os valores.

[cotação: 3]

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
   

Questão 3
Diga para que servem as funções amigas (
friend) duma classe.

[cotação: 3]