9. Tipos Abstratos de Dados
|
|
|
- Paulo Medina Belo
- 9 Há anos
- Visualizações:
Transcrição
1 9. Tipos Abstratos de Dados R. Cerqueira, W. Celes e J.L. Rangel Neste capítulo, discutiremos uma importante técnica de programação baseada na definição de Tipos Abstratos de Dados (TAD). Veremos também como a linguagem C pode nos ajudar na implementação de um TAD, através de alguns de seus mecanismos básicos de modularização (divisão de um programa em vários arquivos fontes) Módulos e Compilação em Separado Como foi visto no capítulo 1, um programa em C pode ser dividido em vários arquivos fontes (arquivos com extensão.c). Quando temos um arquivo com funções que representam apenas parte da implementação de um programa completo, denominamos esse arquivo de módulo. Assim, a implementação de um programa pode ser composta por um ou mais módulos. No caso de um programa composto por vários módulos, cada um desses módulos deve ser compilado separadamente, gerando um arquivo objeto (geralmente um arquivo com extensão.o ou.obj) para cada módulo. Após a compilação de todos os módulos, uma outra ferramenta, denominada ligador, é usada para juntar todos os arquivos objeto em um único arquivo executável. Para programas pequenos, o uso de vários módulos pode não se justificar. Mas para programas de médio e grande porte, a sua divisão em vários módulos é uma técnica fundamental, pois facilita a divisão de uma tarefa maior e mais complexa em tarefas menores e, provavelmente, mais fáceis de implementar e de testar. Além disso, um módulo com funções C pode ser utilizado para compor vários programas, e assim poupar muito tempo de programação. Para ilustrar o uso de módulos em C, considere que temos um arquivo str.c que contém apenas a implementação das funções de manipulação de strings comprimento, copia e concatena vistas no capítulo 6. Considere também que temos um arquivo prog1.c com o seguinte código: #include <stdio.h> int comprimento (char* str); void copia (char* dest, char* orig); void concatena (char* dest, char* orig); int main (void) { char str[101], str1[51], str2[51]; printf("entre com uma seqüência de caracteres: "); scanf(" %50[^\n]", str1); printf("entre com outra seqüência de caracteres: "); scanf(" %50[^\n]", str2); copia(str, str1); concatena(str, str2); printf("comprimento da concatenação: %d\n",comprimento(str)); return 0; A partir desses dois arquivos fontes, podemos gerar um programa executável compilando cada um dos arquivos separadamente e depois ligando-os em um único Estruturas de Dados PUC-Rio 9-1
2 arquivo executável. Por exemplo, com o compilador Gnu C (gcc) utilizaríamos a seguinte seqüência de comandos para gerar o arquivo executável prog1.exe: > gcc c str.c > gcc c prog1.c > gcc o prog1.exe str.o prog1.o O mesmo arquivo str.c pode ser usado para compor outros programas que queiram utilizar suas funções. Para que as funções implementadas em str.c possam ser usadas por um outro módulo C, este precisa conhecer os cabeçalhos das funções oferecidas por str.c. No exemplo anterior, isso foi resolvido pela repetição dos cabeçalhos das funções no início do arquivo prog1.c. Entretanto, para módulos que ofereçam várias funções ou que queiram usar funções de muitos outros módulos, essa repetição manual pode ficar muito trabalhosa e sensível a erros. Para contornar esse problema, todo módulo de funções C costuma ter associado a ele um arquivo que contém apenas os cabeçalhos das funções oferecidas pelo módulo e, eventualmente, os tipos de dados que ele exporte (typedef s, struct s, etc). Esse arquivo de cabeçalhos segue o mesmo nome do módulo ao qual está associado, só que com a extensão.h. Assim, poderíamos definir um arquivo str.h para o módulo do exemplo anterior, com o seguinte conteúdo: /* Funções oferecidas pelo modulo str.c /* Função comprimento ** Retorna o número de caracteres da string passada como parâmetro int comprimento (char* str); /* Função copia ** Copia os caracteres da string orig (origem) para dest (destino) void copia (char* dest, char* orig); /* Função concatena ** Concatena a string orig (origem) na string dest (destino) void concatena (char* dest, char* orig); Observe que colocamos vários comentários no arquivo str.h. Isso é uma prática muito comum, e tem como finalidade documentar as funções oferecidas por um módulo. Esses comentários devem esclarecer qual é o comportamento esperado das funções exportadas por um módulo, facilitando o seu uso por outros programadores (ou pelo mesmo programador algum tempo depois da criação do módulo). Agora, ao invés de repetir manualmente os cabeçalhos dessas funções, todo módulo que quiser usar as funções de str.c precisa apenas incluir o arquivo str.h. No exemplo anterior, o módulo prog1.c poderia ser simplificado da seguinte forma: #include <stdio.h> #include "str.h" int main (void) { char str[101], str1[51], str2[51]; printf("entre com uma seqüência de caracteres: "); scanf(" %50[^\n]", str1); printf("entre com outra seqüência de caracteres: "); scanf(" %50[^\n]", str2); Estruturas de Dados PUC-Rio 9-2
3 copia(str, str1); concatena(str, str2); printf("comprimento da concatenação: %d\n",comprimento(str)); return 0; Note que os arquivos de cabeçalhos das funções da biblioteca padrão do C (que acompanham seu compilador) são incluídos da forma #include <arquivo.h>, enquanto que os arquivos de cabeçalhos dos seus módulos são geralmente incluídos da forma #include "arquivo.h". O uso dos delimitadores < > e " " indica para o compilador onde ele deve procurar esses arquivos de cabeçalhos durante a compilação Tipo Abstrato de Dados Geralmente, um módulo agrupa vários tipos e funções com funcionalidades relacionadas, caracterizando assim uma finalidade bem definida. Por exemplo, na seção anterior vimos um módulo com funções para manipulação de cadeias de caracteres. Nos casos em que um módulo define um novo tipo de dado e o conjunto de operações para manipular dados desse tipo, falamos que o módulo representa um tipo abstrato de dados (TAD). Nesse contexto, abstrato significa esquecida a forma de implementação, ou seja, um TAD é descrito pela finalidade do tipo e de suas operações, e não pela forma como está implementado. Podemos, por exemplo, criar um TAD para representar matrizes alocadas dinamicamente. Para isso, criamos um tipo matriz e uma série de funções que o manipulam. Podemos pensar, por exemplo, em funções que acessem e manipulem os valores dos elementos da matriz. Criando um tipo abstrato, podemos esconder a estratégia de implementação. Quem usa o tipo abstrato precisa apenas conhecer a funcionalidade que ele implementa, não a forma como ele é implementado. Isto facilita a manutenção e o re-uso de códigos. O uso de módulos e TADs são técnicas de programação muito importantes. Nos próximos capítulos, vamos procurar dividir nossos exemplos e programas em módulos e usar tipos abstratos de dados sempre que isso for possível. Antes disso, vamos ver alguns exemplos completos de TADs. Exemplo 1: TAD Ponto Como nosso primeiro exemplo de TAD, vamos considerar a criação de um tipo de dado para representar um ponto no R 2. Para isso, devemos definir um tipo abstrato, que denominaremos de Ponto, e o conjunto de funções que operam sobre esse tipo. Neste exemplo, vamos considerar as seguintes operações: cria: operação que cria um ponto com coordenadas x e y; libera: operação que libera a memória alocada por um ponto; acessa: operação que devolve as coordenadas de um ponto; atribui: operação que atribui novos valores às coordenadas de um ponto; distancia: operação que calcula a distância entre dois pontos. A interface desse módulo pode ser dada pelo código a seguir: Estruturas de Dados PUC-Rio 9-3
4 Arquivo ponto.h: /* TAD: Ponto (x,y) /* Tipo exportado typedef struct ponto Ponto; /* Funções exportadas /* Função cria ** Aloca e retorna um ponto com coordenadas (x,y) Ponto* cria (float x, float y); /* Função libera ** Libera a memória de um ponto previamente criado. void libera (Ponto* p); /* Função acessa ** Devolve os valores das coordenadas de um ponto void acessa (Ponto* p, float* x, float* y); /* Função atribui ** Atribui novos valores às coordenadas de um ponto void atribui (Ponto* p, float x, float y); /* Função distancia ** Retorna a distância entre dois pontos float distancia (Ponto* p1, Ponto* p2); Note que a composição da estrutura Ponto (struct ponto) não é exportada pelo módulo. Dessa forma, os demais módulos que usarem esse TAD não poderão acessar diretamente os campos dessa estrutura. Os clientes desse TAD só terão acesso às informações que possam ser obtidas através das funções exportadas pelo arquivo ponto.h. Agora, mostraremos uma implementação para esse tipo abstrato de dados. O arquivo de implementação do módulo (arquivo ponto.c) deve sempre incluir o arquivo de interface do módulo. Isto é necessário por duas razões. Primeiro, podem existir definições na interface que são necessárias na implementação. No nosso caso, por exemplo, precisamos da definição do tipo Ponto. A segunda razão é garantirmos que as funções implementadas correspondem às funções da interface. Como o protótipo das funções exportadas é incluído, o compilador verifica, por exemplo, se os parâmetros das funções implementadas equivalem aos parâmetros dos protótipos. Além da própria interface, precisamos naturalmente incluir as interfaces das funções que usamos da biblioteca padrão. #include <stdlib.h> /* malloc, free, exit #include <stdio.h> /* printf #include <math.h> /* sqrt #include "ponto.h" Estruturas de Dados PUC-Rio 9-4
5 Como só precisamos guardar as coordenadas de um ponto, podemos definir a estrutura ponto da seguinte forma: struct ponto { float x; float y; ; A função que cria um ponto dinamicamente deve alocar a estrutura que representa o ponto e inicializar os seus campos: Ponto* cria (float x, float y) { Ponto* p = (Ponto*) malloc(sizeof(ponto)); if (p == NULL) { printf("memória insuficiente!\n"); p->x = x; p->y = y; return p; Para esse TAD, a função que libera um ponto deve apenas liberar a estrutura que foi criada dinamicamente através da função cria: void libera (Ponto* p) { free(p); As funções para acessar e atribuir valores às coordenadas de um ponto são de fácil implementação, como pode ser visto a seguir. void acessa (Ponto* p, float* x, float* y) { *x = p->x; *y = p->y; void atribui (Ponto* p, float x, float y) { p->x = x; p->y = y; Já a operação para calcular a distância entre dois pontos pode ser implementada da seguinte forma: float distancia (Ponto* p1, Ponto* p2) { float dx = p2->x p1->x; float dy = p2->y p1->y; return sqrt(dx*dx + dy*dy); Exercício: Escreva um programa que faça uso do TAD ponto definido acima. Exercício: Acrescente novas operações ao TAD ponto, tais como soma e subtração de pontos. Estruturas de Dados PUC-Rio 9-5
6 Exercício: Acrescente novas operações ao TAD ponto, de tal forma que seja possível obter uma representação do ponto em coordenadas polares. Exercício: Implemente um novo TAD para representar pontos no R 3. Exemplo 2: TAD Matriz Como foi discutido anteriormente, a implementação de um TAD fica escondida dentro de seu módulo. Assim, podemos experimentar diferentes maneiras de implementar um mesmo TAD, sem que isso afete os seus clientes. Para ilustrar essa independência de implementação, vamos considerar a criação de um tipo abstrato de dados para representar matrizes de valores reais alocadas dinamicamente, com dimensões m por n fornecidas em tempo de execução. Para tanto, devemos definir um tipo abstrato, que denominaremos de Matriz, e o conjunto de funções que operam sobre esse tipo. Neste exemplo, vamos considerar as seguintes operações: cria: operação que cria uma matriz de dimensão m por n; libera: operação que libera a memória alocada para a matriz; acessa: operação que acessa o elemento da linha i e da coluna j da matriz; atribui: operação que atribui o elemento da linha i e da coluna j da matriz; linhas: operação que devolve o número de linhas da matriz; colunas: operação que devolve o número de colunas da matriz. A interface do módulo pode ser dada pelo código abaixo: Arquivo matriz.h: /* TAD: matriz m por n /* Tipo exportado typedef struct matriz Matriz; /* Funções exportadas /* Função cria ** Aloca e retorna uma matriz de dimensão m por n Matriz* cria (int m, int n); /* Função libera ** Libera a memória de uma matriz previamente criada. void libera (Matriz* mat); /* Função acessa ** Retorna o valor do elemento da linha i e coluna j da matriz float acessa (Matriz* mat, int i, int j); /* Função atribui ** Atribui o valor dado ao elemento da linha i e coluna j da matriz void atribui (Matriz* mat, int i, int j, float v); /* Função linhas ** Retorna o número de linhas da matriz int linhas (Matriz* mat); Estruturas de Dados PUC-Rio 9-6
7 /* Função colunas ** Retorna o número de colunas da matriz int colunas (Matriz* mat); A seguir, mostraremos a implementação deste tipo abstrato usando as duas estratégias apresentadas no capítulo 8: matrizes dinâmicas representadas por vetores simples e matrizes dinâmicas representadas por vetores de ponteiros. A interface do módulo independe da estratégia de implementação adotada, o que é altamente desejável, pois podemos mudar a implementação sem afetar as aplicações que fazem uso do tipo abstrato. O arquivo matriz1.c apresenta a implementação através de vetor simples e o arquivo matriz2.c apresenta a implementação através de vetor de ponteiros. Arquivo matriz1.c: #include <stdlib.h> /* malloc, free, exit #include <stdio.h> /* printf #include "matriz.h" struct matriz { int lin; int col; float* v; ; Matriz* cria (int m, int n) { Matriz* mat = (Matriz*) malloc(sizeof(matriz)); if (mat == NULL) { printf("memória insuficiente!\n"); mat->lin = m; mat->col = n; mat->v = (float*) malloc(m*n*sizeof(float)); return mat; void libera (Matriz* mat){ free(mat->v); free(mat); float acessa (Matriz* mat, int i, int j) { int k; /* índice do elemento no vetor if (i<0 i>=mat->lin j<0 j>=mat->col) { printf("acesso inválido!\n"); k = i*mat->col + j; return mat->v[k]; void atribui (Matriz* mat, int i, int j, float v) { int k; /* índice do elemento no vetor if (i<0 i>=mat->lin j<0 j>=mat->col) { printf("atribuição inválida!\n"); Estruturas de Dados PUC-Rio 9-7
8 k = i*mat->col + j; mat->v[k] = v; int linhas (Matriz* mat) { return mat->lin; int colunas (Matriz* mat) { return mat->col; Arquivo matriz2.c: #include <stdlib.h> /* malloc, free, exit #include <stdio.h> /* printf #include "matriz.h" struct matriz { int lin; int col; float** v; ; Matriz* cria (int m, int n) { int i; Matriz* mat = (Matriz*) malloc(sizeof(matriz)); if (mat == NULL) { printf("memória insuficiente!\n"); mat->lin = m; mat->col = n; mat->v = (float**) malloc(m*sizeof(float*)); for (i=0; i<m; i++) mat->v[i] = (float*) malloc(n*sizeof(float)); return mat; void libera (Matriz* mat) { int i; for (i=0; i<mat->lin; i++) free(mat->v[i]); free(mat->v); free(mat); float acessa (Matriz* mat, int i, int j) { if (i<0 i>=mat->lin j<0 j>=mat->col) { printf("acesso inválido!\n"); return mat->v[i][j]; void atribui (Matriz* mat, int i, int j, float v) { if (i<0 i>=mat->lin j<0 j>=mat->col) { printf("atribuição inválida!\n"); mat->v[i][j] = v; int linhas (Matriz* mat) { return mat->lin; Estruturas de Dados PUC-Rio 9-8
9 int colunas (Matriz* mat) { return mat->col; Exercício: Escreva um programa que faça uso do TAD matriz definido acima. Teste o seu programa com as duas implementações vistas. Exercício: Usando apenas as operações definidas pelo TAD matriz, implemente uma função que determine se uma matriz é ou não quadrada simétrica. Exercício: Usando apenas as operações definidas pelo TAD matriz, implemente uma função que, dada uma matriz, crie dinamicamente a matriz transposta correspondente. Exercício: Defina um TAD para implementar matrizes quadradas simétricas, de acordo com a representação sugerida no capítulo 8. Estruturas de Dados PUC-Rio 9-9
Tipos Abstratos de Dados (TAD)
Instituto de C Tipos Abstratos de Dados (TAD) Luis Martí Instituto de Computação Universidade Federal Fluminense [email protected] - http://lmarti.com Tópicos Principais Módulos e Compilação em separado
INF1007: Programação 2 9 Tipos Abstratos de Dados. (c) Dept. Informática - PUC-Rio 1
INF1007: Programação 2 9 Tipos Abstratos de Dados (c) Dept. Informática - PUC-Rio 1 Tópicos Módulos e compilação em separado Tipo abstrato de dados Exemplo 1: TAD Ponto Exemplo 2: TAD Círculo Exemplo 3:
Programação de Computadores II. Cap. 9 Tipos Abstratos de Dados (TAD)
Programação de Computadores II Cap. 9 Tipos Abstratos de Dados (TAD) Livro: Waldemar Celes, Renato Cerqueira, José Lucas Rangel. Introdução a Estruturas de Dados, Editora Campus (2004) Slides adaptados
TAD: Tipo Abstrato de Dados (parte 2)
TAD: Tipo Abstrato de Dados (parte 2) SCC0202 Algoritmos e Estruturas de Dados I Prof. Thiago A. S. Pardo Modularização em C Programa em C pode ser dividido em vários arquivos Arquivos fonte com extensão.c
TAD: Tipo Abstrato de Dados (parte 2)
TAD: Tipo Abstrato de Dados (parte 2) SCC0502 Algoritmos e Estruturas de Dados I Programa em C pode ser dividido em vários arquivos Arquivos fonte com extensão.c Denominados de módulos Cada módulo deve
Algoritmos e Estruturas de Dados II IEC013
Algoritmos e Estruturas de Dados II IEC013 TAD, Pilhas e Filas Prof. César Melo Todos os créditos ao Prof. Leandro Galvão TAD: Definição SE programa = definição de um tipo de dados + operação sobre dados
Programação II. Módulos, Encapsulamento e TADs. Bruno Feijó Dept. de Informática, PUC-Rio
Programação II Módulos, Encapsulamento e TADs Bruno Feijó Dept. de Informática, PUC-Rio Módulos Programação modular é uma técnica de design de software na qual particionamos o programa em diversos módulos
TAD: Tipo Abstrato de Dados (parte 2) SCE-202 Algoritmos e Estruturas de Dados I
TAD: Tipo Abstrato de Dados (parte 2) SCE-202 Algoritmos e Estruturas de Dados I Modularização em C Programa em C pode ser dividido em vários arquivos Arquivos fonte com extensão.c Denominados de módulos
Referências. Programação de Computadores II. Cap. 7 Cadeias de Caracteres. Caracteres. Tópicos
Referências Programação de Computadores II Cap. 7 Cadeias de Caracteres Waldemar Celes, Renato Cerqueira, José Lucas Rangel, Introdução a Estruturas de Dados, Editora Campus (2004) Capítulo 7 Livro: Waldemar
Guia Rápido: GCC, Makefile e Valgrind.
Guia Rápido: GCC, Makefile e Valgrind. Alexandro Ramos 10 de setembro de 2015 1 Sumário 1 Introdução 3 2 GCC 3 2.1 Outros parâmetros úteis no GCC....................... 4 3 Makefiles 6 3.1 Makefile 1....................................
3. COMPILAÇÃO E ESTRUTURA BÁSICA DE UM PROGRAMA EM C
3. COMPILAÇÃO E ESTRUTURA BÁSICA DE UM PROGRAMA EM C 3.1. Compilação de um Programa C O compilador C realiza a compilação do código-fonte de um programa em cinco etapas: edição, pré-processamento, compilação,
Aula 3/4: Vetores/Matrizes e Ponteiros
Carlos Henrique/Introdução C++ Aula 3/4: Vetores/Matrizes e Ponteiros Funções: Função main (int argc, char ** argv) Recursão Vetores/Matrizes/Strings Vetor (Matriz Unidimensional) Gerando um ponteiro para
AULA 3 Alocação dinâmica de memória: Ponteiros
UNIP - Ciência da Computação e Sistemas de Informação Estrutura de Dados AULA 3 Alocação dinâmica de memória: Ponteiros Estrutura de Dados 1 Variáveis X Ponteiros VARIÁVEL - Estrutura para armazenamento
INF 1007 Programação II
INF 1007 Programação II Aula 12 Tipos Abstratos de Dados Edirlei Soares de Lima Tipo Abstrato de Dados (TAD) Um TAD define: Um novo tipo de dado; O conjunto de operações para manipular
Programação II. Tipos Estruturados. Bruno Feijó Dept. de Informática, PUC-Rio
Programação II Tipos Estruturados Bruno Feijó Dept. de Informática, PUC-Rio Dados Compostos Até agora tipos simples: char, int, float,. Necessidade por dados compostos, por tipos estruturados Ex.: pontos
Programação de Computadores I. Linguagem C Função
Linguagem C Função Prof. Edwar Saliba Júnior Fevereiro de 2011 Unidade 07 Função 1 Conceitos As técnicas de programação dizem que, sempre que possível, evite códigos extensos, separando o mesmo em funções,
SCC 202 Prova 1. 28/9/2010 Resolução e Comentários
SCC 202 Prova 1 28/9/2010 Resolução e Comentários Questão 1) (3.5) Sobre TADs. a) O que é e quais são as vantagens de se utilizar Tipos Abstratos de Dados (TADs) no projeto de desenvolvimento de software?
Estruturas de Dados Aula 9: Listas (parte 1) 05/04/2011
Estruturas de Dados Aula 9: Listas (parte 1) 05/04/2011 Fontes Bibliográficas Livros: Projeto de Algoritmos (Nivio Ziviani): Capítulo 3; Introdução a Estruturas de Dados (Celes, Cerqueira e Rangel): Capítulo
2. Tipos Abstratos de Dados
2. Tipos Abstratos de Dados Um Tipo Abstrato de Dados especifica uma classe de dados definida pelo usuário em termos de suas propriedades abstratas Esta especificação do TAD descreve o comportamento de
Tipos Abstratos de Dados TADs
Tipos Abstratos de Dados TADs Exemplo Folha de freqüência Disciplina: Estruturas de Dados I Semestre: 2013-2 Turmas: U Professor: Sandra matricula nome......... XXXX ZZZZ YYYY Ana Maria Pedro Operações:
1 Cálculo do valor à vista
MAC-5 Introdução à Computação para Ciências Exatas e Tecnologia IO Segundo Exercício Programa Entregar até 7/0/2007 Comprar à vista ou comprar à prazo? Várias lojas já possuem alguns planos de crediário
Trabalho Prático II - Resta 1 Data de Entrega: Conferir no calendário!
ALGORITMOS E ESTRUTURAS DE DADOS I DCC/UFMG Trabalho Prático II - Resta 1 Data de Entrega: Conferir no calendário! Pedro O.S. Vaz de Melo May 29, 2013 1 DESCRIÇÃO DO PROBLEMA O objetivo deste trabalho
1. Estrutura de Dados
1. Estrutura de Dados Não existe vitória sem sacrifício! Filme Transformers Um computador é uma máquina que manipula informações. O estudo da ciência da computação inclui o exame da organização, manipulação
TUTORIAL MATLAB Victor Breder 2016
TUTORIAL MATLAB Victor Breder 2016 1. INTERFACE A. Caminho de trabalho Mostra o caminho pasta raiz que será considerada para executar scripts e funções criados pelo usuário. B. Pasta de trabalho Mostra
Orientação a Objetos
Orientação a Objetos 1. Manipulando Atributos Podemos alterar ou acessar os valores guardados nos atributos de um objeto se tivermos a referência a esse objeto. Os atributos são acessados pelo nome. No
INTRODUÇÃO À PROGRAMAÇÃO II VARIÁVEIS COMPOSTAS HOMOGÊNEAS UNIDIMENSIONAIS
INTRODUÇÃO À PROGRAMAÇÃO II VARIÁVEIS COMPOSTAS HOMOGÊNEAS UNIDIMENSIONAIS Material da Prof. Ana Eliza Dados e comandos, para serem processados, devem estar na memória do computador. Memória Definição:
2) Escreva um algoritmo que leia um conjunto de 10 notas, armazene-as em uma variável composta chamada NOTA e calcule e imprima a sua média.
1) Inicializar um vetor de inteiros com números de 0 a 99 2) Escreva um algoritmo que leia um conjunto de 10 notas, armazene-as em uma variável composta chamada NOTA e calcule e imprima a sua média 3)
INF 1620 P1-04/10/03 Questão 1 Nome:
INF 1620 P1-04/10/03 Questão 1 a) Implemente uma função para calcular as raízes de uma equação do segundo grau do tipo ax 2 +bx+c=0. O protótipo dessa função deve ser: void raizes (float a, float b, float
Introdução. Software Básico Aula 3. Prof. Dr. Rogério Vargas.
Introdução Software Básico Aula 3 Prof. Dr. Rogério Vargas http://rogerio.in Provocação Você já se perguntou como é que os programas que você escreve são traduzidos em instruções executáveis pelas estruturas
PROGRAMAÇÃO DE COMPUTADORES I
PROGRAMAÇÃO DE COMPUTADORES I (Parte 2) Prof. Eduardo Machado Real Conteúdos: Variáveis Compostas Homogêneas: Vetores e Matrizes. Variáveis Compostas Heterogêneas: Registros. Programação de Computadores
Estruturas de Repetição
Estruturas de Repetição Lista de Exercícios - 04 Algoritmos e Linguagens de Programação Professor: Edwar Saliba Júnior Estruturas de Repetição O que são e para que servem? São comandos que são utilizados
Conceitos básicos de programação
Tipos de dados estruturados Tipos estruturados vectores matrizes Estruturas (registos) Vectores e matrizes são estruturas homogéneas. Uma estrutura homogénea é uma sequência linear de elementos de mesmo
- Campus Salto. Disciplina: Sistemas de Arquivos Docente: Fernando Santorsula E-mail: [email protected]
Disciplina: Sistemas de Arquivos Docente: Fernando Santorsula E-mail: [email protected] Sistemas de Arquivos- Parte 2 Pontos importantes de um sistema de arquivos Vários problemas importantes devem
Linguagem C: strings. Prof. Críston Algoritmos e Programação
Linguagem C: strings Prof. Críston Algoritmos e Programação String Uma string é um vetor de caracteres (texto) char nome [tamanho]; O texto que vamos gravar em uma string não precisa ocupar todos os caracteres
INF 1620 P2-01/11/03 Questão 1 Nome:
INF 1620 P2-01/11/03 Questão 1 Considere a implementação de uma lista encadeada para armazenar as notas dos alunos de uma turma dada pelo tipo abaixo: struct lista { char nome[81]; int mat; float p1, p2,
Conceitos c++ Prof. Demétrios Coutinho INFORMÁTICA BÁSICA
INFORMÁTICA BÁSICA Conceitos c++ Prof. Demétrios Coutinho C a m p u s P a u d o s F e r r o s D i s c i p l i n a d e O r g a n i z a ç ã o d e A l g o r i t m o s D e m e t r i o s. c o u t i n h o @
Estruturas de Dados. Módulo 13 - Árvores. 9/8/2005 (c) Dept. Informática - PUC-Rio 1
Estruturas de Dados Módulo 13 - Árvores 9/8/2005 (c) Dept. Informática - PUC-Rio 1 Referências Waldemar Celes, Renato Cerqueira, José Lucas Rangel, Introdução a Estruturas de Dados, Editora Campus (2004)
Linguagem C. Introdução à Programação C. Variáveis. Identificadores. Identificadores 12/03/2011 VARIÁVEIS E TIPOS DE DADOS
Linguagem C Introdução à Programação C Introdução à Ciência da Computação I Prof. Denis F. Wolf Origem de C está associada ao sistema Unix Histórico: 1970: Ken Thompson desenvolve B, baseada em BCPL, para
Algoritmos e Estruturas de dados
Algoritmos e Estruturas de dados Listas Encadeadas Prof. Dr. Fábio Rodrigues de la Rocha (Listas Encadeadas) 1 / 21 Definição: Anteriormente estudamos listas encadeadas que foram implementadas como vetores
Exemplo Tipos Abstratos de Dados TADs Disciplina: Semestre: Turma: Professor: Renata de Matos Galante matricula nome
Tipos Abstratos de Dados TADs Renata de Matos Galante Universidade Federal do Rio Grande do Sul Instituto de Informática INF 01203 Estruturas de Dados [email protected] Eemplo Folha de freqüência Disciplina:
Estruturas de Dados. Introdução Definição de Ponteiros Declaração de Ponteiros em C Manipulação de Ponteiros em C
Estruturas de Dados Revisão de Ponteiros Prof. Ricardo J. G. B. Campello Sumário Introdução Definição de Ponteiros Declaração de Ponteiros em C Manipulação de Ponteiros em C Operações Ponteiros e Arranjos
PROGRAMAÇÃO FUNÇÕES NA LINGUAGEM C
PROGRAMAÇÃO FUNÇÕES NA LINGUAGEM C 1 Implementações básicas : a) Implementar a função LerValorValido que verifica se um valor introduzido pelo utilizador pertence ao conjunto limitado por dois dados valores
Algoritmos e Programação
Algoritmos e Programação Aula 3 Introdução a Linguagem C Profa. Marina Gomes [email protected] 1 Aula de Hoje - Criar programas simples em C utilizando a estrutura básica; - Declarar variáveis;
Alocação de Memória. Lucas Ferrari de Oliveira Professor Adjunto Universidade Federal do Paraná (UFPR)
Alocação de Memória Linguagem de Programação Estruturada 1 Alocação dinâmica e ponteiros Lucas Ferrari de Oliveira Professor Adjunto Universidade Federal do Paraná (UFPR) Sumario Introdução Alocação Estática
Universidade Federal de Uberlândia - UFU Faculdade de Computação - FACOM Lista de exercícios de programação em linguagem C. Exercícios: Structs
Universidade Federal de Uberlândia - UFU Faculdade de Computação - FACOM Lista de exercícios de programação em linguagem C Exercícios: Structs 1. Utilizando estrutura, fazer um programa em C que permita
COMO VENDER MAIS USANDO FUNIL DE VENDAS. Capítulo III: Etapas do Funil de Vendas
COMO VENDER MAIS USANDO FUNIL DE VENDAS Capítulo III: Etapas do Funil de Vendas Índice Introdução Defina suas etapas de vendas corretamente Como definir suas etapas de vendas 03 05 06 2 Introdução Olá,
Algoritmos e Estruturas de Dados I. Variáveis Indexadas. Pedro O.S. Vaz de Melo
Algoritmos e Estruturas de Dados I Variáveis Indexadas Pedro O.S. Vaz de Melo Por que índices são importantes? Como uma loja de sapatos artesanais deve guardar os seus produtos? 1 2 3 4 Tamanhos entre
Tipos Abstratos de Dados. Estrutura de Dados
Tipos Abstratos de Dados Tipo Abstrato de Dados ou TAD Idéia principal: desvincular o tipo de dado (valores e operações) de sua implementação: O que o tipo faz e não como ele faz! Vantagens da desvinculação:
INF 1007 Simulado P2 Nome: Instruções
INF 1007 Simulado P2 Nome: Matrícula: Turma: Instruções 1. Tempo de prova: 1 hora e 30 minutos. 2. Entregue a solução de sua prova em um ÚNICO arquivo texto, com o nome Turma_Matricula_P2.txt (por exemplo
Vetores, Matrizes e String
Vetores, Matrizes e String Escola CDI Professor: Paulo Marcos Trentin O que é um Vetor? Conhecido também como matriz unidimensional, é uma variável que pode conter vários valores do mesmo tipo de dado.
Métodos Computacionais. Tipos Estruturados
Métodos Computacionais Tipos Estruturados Tipos Estruturados C oferece tipos primitivos que servem para representar valores simples Reais (float, double), inteiros (int), caracter (char) C oferece também
Avaliação e Desempenho Aula 1 - Simulação
Avaliação e Desempenho Aula 1 - Simulação Introdução à simulação Geração de números aleatórios Lei dos grandes números Geração de variáveis aleatórias O Ciclo de Modelagem Sistema real Criação do Modelo
Introdução a Programação. Ponteiros e Strings, Alocação Dinâmica
Introdução a Programação Ponteiros e Strings, Alocação Dinâmica Tópicos da Aula Hoje aprenderemos a relação entre ponteiros e strings Ponteiros para strings X Vetores de Caracteres Vetores de ponteiros
INF 1007 Programação II
INF 1007 Programação II Aula 08 Vetor de Ponteiros Edirlei Soares de Lima Vetor de Cadeia de Caracteres Um vetor de cadeia de caracteres pode ser alocado de duas formas: Alocação
21 Strings. 21.1 O que são strings? 21.2 Leitura de Strings. Ronaldo F. Hashimoto e Carlos H. Morimoto
21 Strings Ronaldo F. Hashimoto e Carlos H. Morimoto Oobjetivodestaaulaéintroduziroconceitodestrings. Aofinaldessaaulavocêdeverásaber: Descrever o que são strings. Descrever a distinção entre strings evetoresdecaracteres.
Métodos Computacionais. Vetores e Matrizes Dinâmicas
Métodos Computacionais Vetores e Matrizes Dinâmicas Vetores Um programa para o cálculo da média Média m n i= = 1 n x i Variância v n i= = 1 ( x i n m) 2 A forma mais simples de estruturar um conjunto de
LINGUAGEM SQL Linguagem usada em SGBD para: Definir estrutura de dados; Modificar dados em um banco de dados; Especificar restrições de segurança; Rea
BANCO DE DADOS Prof. Fabiano Taguchi http://fabianotaguchi.wordpress.com [email protected] SQL A Structed Query Language foi desenvolvida em 1974 nos laboratório da IBM em San José na Califórnia,
MC-102 - Teste de Mesa e Comandos Repetitivos
MC-102 - Teste de Mesa e Comandos Repetitivos Elaborado por Raoni Teixeira e Editado por Danillo Roberto Pereira Instituto de Computação Unicamp Primeiro Semestre de 2013 Introdução Introdução Pode acontecer
BCC202 - Estrutura de Dados I
BCC202 - Estrutura de Dados I Aula 02: Alocação Dinâmica de Memória Reinaldo Fortes Universidade Federal de Ouro Preto, UFOP Departamento de Ciência da Computação, DECOM Website: www.decom.ufop.br/reifortes
Conversão Visualg à C++ Prof. Paulo Cesar F. de Oliveira, BSc, PhD
Conversão Visualg à C++ Prof. Paulo Cesar F. de Oliveira, BSc, PhD 1 Unidade 01-a Algoritmos e Programação Seção 1.1 Visualg 2 Formato do Visualg algoritmo nome do algoritmo // Função: // Autor: // Data:
3. Linguagem de Programação C
Introdução à Computação I IBM1006 3. Linguagem de Programação C Prof. Renato Tinós Departamento de Computação e Matemática (FFCLRP/USP) 1 Principais Tópicos 3.2. Estrutura de Programas e Representação
Algoritmos e Programação : Conceitos e estruturas básicas. Hudson Victoria Diniz
Algoritmos e Programação : Conceitos e estruturas básicas Hudson Victoria Diniz Relembrando... Um algoritmo é formalmente uma seqüência finita de passos que levam a execução de uma tarefa. Podemos pensar
Linguagem de Programação C. Fluxo de Saída Padrão. Linguagem de Programação C. printf. Fluxo de Saída Padrão. Algoritmos e Lógica de Programação
Algoritmos e Lógica de Programação Linguagem de Programação C Linguagem C Entrada e Saída de dados Reinaldo Gomes [email protected] Fluxo de Saída Padrão Saída Formatada: ( ) Tem a função de
1.1. Definição do Problema
13 1 Introdução Uma das principais preocupações de área de engenharia de software diz respeito à reutilização [1]. Isso porque a reutilização no contexto de desenvolvimetno de software pode contribuir
Padrões de Projeto. Factory Method
Padrões de Projeto Padrões de Criação Factory Method Prof. Eduardo N F Zagari Prof. Ivan Granja Factory Method Também conhecido como Construtor Virtual Em muitas aplicações OO, um objeto cliente precisa
Capítulo 5: Repetições
Capítulo 5: Repetições INF1004 e INF1005 Programação 1 Pontifícia Universidade Católica Departamento de Informática Construção de Laços Repetição: Diversos problemas de difícil solução podem ser resolvidos
