27
Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Embed Size (px)

Citation preview

Page 1: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Programação II

Tipos Compostos Heterogêneos e Tipos Abstratos de Dados

Autoria: Ernani SantosModificação: Clebson OliveiraAdaptação: Claudia Boeres

Page 2: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

As formas básicas de representação de dados não são suficientes para representar tipos compostos heterogêneos;

Organizar dados correlacionados em uma única entidade computacional promove vantagens;

Essas entidades são chamadas de Estruturas em C; As Estruturas são entidades que representam tipos de

dados que permitem o agrupamento de varias variáveis de diversos tipos.

Tipos Compostos Heterogêneos

Page 3: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Exemplo:

3

Tipos Compostos Heterogêneos

Page 4: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Definição:

4

Tipos Compostos Heterogêneos

Page 5: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Exemplo:

Tipos Compostos Heterogêneos

Page 6: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Para manipular cada um dos atributos da estrutura se utiliza o mecanismo de seleção conforme a sintaxe apresentada a seguir.

<nome da variável>.<nome do atributo> Exemplo:

Tipos Compostos Heterogêneos

Page 7: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Typedef: serve para atribuir um nome a uma estrutura e definir um tipo.

Exemplo:

Tipos Compostos Heterogêneos

struct e tipos definidos pelo usuário

Page 8: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Exemplos: a) Cálculo da distância entre dois pontosno plano cartesiano

b) Manipulação de pontos no plano

Tipos Compostos Heterogêneos

Exemplo 2

Exemplo 1

Page 9: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Exemplos: a) vetor de pontos: exemplo vetor

b) vetor de pontos aleatórios no plano: vetor de pontos aleatórios

Tipos Compostos Heterogêneos

Page 10: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Tipos Abstratos de Dados (TADs)

Conjuntos de valores com comportamento uniforme definido por operações;

Em LPs, TADs possuem representação e operações especificadas pelo programador;

O usuário do TAD utiliza sua representação e operações como uma caixa preta;

Essencial haver ocultamento da informação para tornar invisível a implementação;

Interface são os componentes públicos do TAD (tipicamente, operações).

Page 11: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Encapsulam e protegem os dados. Resolvem os problemas existentes com tipos simples. Quatro tipos diferentes de operações:

Construtoras; Consultoras; Atualizadoras; Destrutoras.

Tipos Abstratos de Dados (TADs)

Page 12: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Dados

Operações(consultoras)

Operações(construtoras)

Operações(atualizadoras)

Operações(destrutoras)

CódigoUsuário

TAD

Tipos Abstratos de Dados (TADs)

Page 13: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Simulação de TADs em C C não apresenta ferramentas para implementar TADs; Apenas podemos simular TADs em C; Uso disciplinado dessa simulação promove:

Maior legibilidade A leitura da interface (.h) mostra todas as

funcionalidades do TAD. Maior redigibilidade

Usuário não implementa operações. Maior modificabilidade

Alterações no TAD não provocam alterações no código usuário.

Page 14: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Uso indisciplinado da simulação: Programador pode não chamar a operação de

inicialização; Programador pode usar outras operações

para acessar o TAD, acabando com todas as vantagens do uso de TADs .

Simulação de TADs em C

Page 15: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Implementação de um vetor usando um TAD

15

Page 16: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Implementação de um vetor usando um TAD

16

Page 17: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Algumas Operações

17

Page 18: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Utilização do TAD

18

Page 19: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

TAD matriz de números inteiros

• Estrutura– Atributos

• Operações– Inicializar, modificar, operar com, exibição

19

Page 20: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Estrutura do TAD Matriz

20

Uma matriz de duas dimensões sendo que pode ter, no máximo, a dimensão 5x5, mas tem as dimensões definidas pelos valores dos atributos lin e col.

Matriz m;

Page 21: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

1 int main() {23 int i,j;1 Matriz m;2 3 m.lin=3;4 m.col=3;5 6 for (i=0; i<m.lin; i++) {7 for(j=0; j<m.col; j++) {8 m.val[i][j] = 0;9 }10 }1415 return 0;16 }

Inicialização

21

Inicialização explícita de todos os elementos da matriz usando o TAD

0 1 2

0

1

2

Page 22: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Operação de construção

22

Page 23: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Operação de atribuição de valores

23

Page 24: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Operação de buscar de valor

24

Page 25: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Operação de exibição

25

Page 26: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Programa de teste

26

Page 27: Programação II Tipos Compostos Heterogêneos e Tipos Abstratos de Dados Autoria: Ernani Santos Modificação: Clebson Oliveira Adaptação: Claudia Boeres

Resultado

27