Difference between revisions of "Polimorfismo, Interfaces, Classes Abstractas/Exercício 04: Tabelas e Transformações"

From Wiki**3

< Polimorfismo, Interfaces, Classes Abstractas
(Conceito de Tabela)
 
Line 12: Line 12:
 
== Conceito de Tabela ==
 
== Conceito de Tabela ==
  
<java5>
+
<source lang="java">
 
public class Table {
 
public class Table {
  
Line 27: Line 27:
  
 
}
 
}
</java5>
+
</source>
  
 
== Conceito de Transformação ==
 
== Conceito de Transformação ==
  
<java5>
+
<source lang="java">
  
 
public interface Transform {
 
public interface Transform {
Line 37: Line 37:
 
}
 
}
  
</java5>
+
</source>
  
 
== Conceito de Sucessor  ==
 
== Conceito de Sucessor  ==
  
<java5>
+
<source lang="java">
 
public class Successor implements Transform {
 
public class Successor implements Transform {
 
   
 
   
Line 50: Line 50:
 
   
 
   
 
}
 
}
</java5>
+
</source>
  
 
== Conceito de Quadrado  ==
 
== Conceito de Quadrado  ==
  
<java5>
+
<source lang="java">
 
public class Square implements Transform {
 
public class Square implements Transform {
 
   
 
   
Line 63: Line 63:
 
   
 
   
 
}
 
}
</java5>
+
</source>
  
 
== Programa Principal ==
 
== Programa Principal ==
Line 69: Line 69:
 
O programa principal é como indicado no enunciado do problema e indicado abaixo para clarificação:
 
O programa principal é como indicado no enunciado do problema e indicado abaixo para clarificação:
  
<java5>
+
<source lang="java">
 
public class Application {
 
public class Application {
 
   //TODO
 
   //TODO
 
}
 
}
</java5>
+
</source>
  
 
= Compiling and Running =
 
= Compiling and Running =

Latest revision as of 19:26, 29 October 2019

Problema

Modele e implemente a classe Table que contém um número fixo de inteiros (especificado na altura da criação das suas instâncias). Essa classe possui um método (print) que permite imprimir todo o conteúdo, aplicando uma transformação a cada valor. A transformação aplicada varia de acordo com o tipo do objecto Transform, passado como como argumento de print. As potenciais transformações têm um método transform (aceita um inteiro e devolve outro inteiro) que permite modificar um valor inteiro de uma forma específica. Defina os conceitos Table e Transform. Defina ainda duas transformações: uma que calcula o sucessor de cada inteiro (Successor); e outra que calcule o quadrado de cada um dos valores da tabela (Square). Pode realizar outros conceitos/métodos que julgue necessitar. Evite repetições de código.

Solução

UML: Diagrama de Classes

PO-tables-transforms.png

Conceito de Tabela

public class Table {

  private int _vector[];

  public Table(int size) {
    _vector = new int[size];
    // init table here...
  }

  public void print(Transform t) {
    for (int i: _vector) System.out.println(t.transform(i));
  }

}

Conceito de Transformação

public interface Transform {
  int transform(int i);
}

Conceito de Sucessor

public class Successor implements Transform {
 
  @Override
  public int transform(int i) {
    return i + 1;
  }
 
}

Conceito de Quadrado

public class Square implements Transform {
 
  @Override
  public int transform(int i) {
    return i * i;
  }
 
}

Programa Principal

O programa principal é como indicado no enunciado do problema e indicado abaixo para clarificação:

public class Application {
  //TODO
}

Compiling and Running

How to Compile?

The compilation is as follows:

 javac Table.java
 javac Transform.java
 javac Successor.java
 javac Square.java
 javac Application.java

In fact, compiling Application.java would cause the rest of them be compiled as well (the Java compiler accounts for all explicit class dependencies).

Running

The program starts at a main function (in this case, contained in the Application class):

 java Application