![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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/1.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/2.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/3.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/4.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/5.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/6.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/7.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/8.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/9.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/10.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/11.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/12.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/13.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/14.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/15.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/16.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/17.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/18.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/19.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/20.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/21.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/22.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/23.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/24.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/25.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/26.jpg)
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](https://reader036.vdocuments.net/reader036/viewer/2022070508/570638691a28abb823903d0f/html5/thumbnails/27.jpg)
Resultado
27