PROGRAMAÇÃO DE MICROPROCESSADORES 2011 / 2012
|
|
|
- Júlio César Damásio Tuschinski
- 9 Há anos
- Visualizações:
Transcrição
1 Departamento de Engenharia Electrotécnica PROGRAMAÇÃO DE MICROPROCESSADORES 2011 / 2012 Mestrado Integrado em Engenharia Electrotécnica e Computadores 1º ano 1º semestre Trabalho nº 5 Funções Paulo da Fonseca Pinto Luis Bernardo
2 1 Introdução O capítulo 5 do livro Linguagem C de Luís Damas, recomendado para a disciplina de Programação de Microprocessadores, é dedicado às funções. Esta aula visa consolidar estas matérias através de um conjunto de exercícios. Faça todos os exercícios pedidos em ficheiros separados e GUARDE O CÓDIGO desenvolvido na memória USB. Durante a aula o docente pode pedir-lhe para mostrar o código desenvolvido. 2 Como escrever um ficheiro com funções? 2.1 ONDE COLOCAR AS FUNÇÕES? Uma pergunta pertinente quando se escreve o código de um programa com funções é saber onde colocar as funções e o main. Deve ser como está mostrado em baixo à esquerda, ou à direita? main () int i= 4, n=2; escreve_num (i, n); void escreve_num (int a, b) printf ("N1 = %d, N2 0 %d\n, a, b); void escreve_num (int a, b) printf ("N1 = %d, N2 0 %d\n, a, b); main () int i= 4, n=2; escreve_num (i, n); PORQUÊ? O compilador de C vai percorrendo o ficheiro do princípio ao fim, compilando o programa. Se usarmos o modo à esquerda, quando o compilador encontra a função escreve_num, como ainda não a conhece, admite que ela devolve int. É assim que o compilador de C funciona! Quando chega à função propriamente dita repara que existe uma função que devolve void, mas que tem o mesmo nome de uma outra que ele já conhece, só que esta devolve int. Ora só pode ser uma função diferente, mas não se pode ter funções diferentes com o mesmo nome. O compilador detecta um erro! Existe uma solução para estes casos: Escrever um protótipo da função escreve_num antes do main para indicar ao compilador que escreve_num devolve void. 2
3 Ora quanto mais se escreve, mais se erra! Se a meio de programar decidirmos mudar alguma coisa na função temos de ir mudar o protótipo. Assim, para simplificar, vai-se fazer a seguinte regra: É proibido usar protótipos em Programação de Microprocessadores. Só se poderá usar no caso de se utilizar mais do que um ficheiro para escrever o código. ENTÃO O QUE SE DEVE FAZER? Deve-se usar o modo de escrita apresentado à direita. O main é sempre a última função no ficheiro e sempre que se chama uma função, chama-se para cima (isto é, o código dela está escrito em cima). Deste modo não são precisos os protótipos. 2.2 AS VARIÁVEIS GLOBAIS Para este assunto não vão ser dadas muitas explicações: É proibido usar variáveis globais em Programação de Microprocessadores. 3
4 3 A tabuada Pretende-se utilizar o código seguinte, sem alterar qualquer linha já escrita, para fazer a tabuada. Acrescente o que for preciso num ficheiro tabuada.c. /* * Tabuada * Ficheiro: tabuada.c */ #include <stdlib.h> /* define exit() para sair do programa */ int mult (int a, b) return a*b; main () int n; printf ("Que tabuada quer (1 a 9)? : "); if (scanf (" %d", &n)!= 1) /* Se não leu um elemento */ printf ("Leitura do limite inválida\n"); exit (1); /* Sai do programa */ if ((n < 1) (n > 9)) printf ( Número incorrecto. Tente outra vez\n ); exit (1); tabuada (n); O programa deve proceder como este exemplo. Pode depois mudar o código para ficar sempre a perguntar. Que tabuada quer (1 a 9)? : 5 5 x 1 = 5 5 x 2 = 10 5 x 3 = 15 5 x 4 = 20 5 x 5 = 25 5 x 6 = 30 5 x 7 = 35 5 x 8 = 40 5 x 9 = 45 Que tabuada quer (1 a 9)? : 4
5 4 Exercício Final: Jogo do mais ou menos Este exercício foi baseado num exercício semelhante de anos passados da autoria de Yves Rybarczyk e Vasco Gomes. 4.1 DESCRIÇÃO GERAL O objectivo é construir um jogo para que o utilizador descubra um número mistério. O nível do jogo, o número máximo de tentativas e a escolha do número mistério podem ser decididos por outro jogador, ou o próprio programa pode calculá-los por sorteio. Existe assim uma fase de preparação de jogo, e uma fase de execução de jogo. No final da execução, o programa deve perguntar se se deve repetir tudo. Repare que a fase de execução do jogo é igual para os dois casos (haver um outro jogador a decidir as coisas, ou ser o próprio programa). O programa deve começar por perguntar se a escolha deve ser feita por uma pessoa, ou automaticamente. No caso de ser por uma pessoa o programa pergunta o máximo de tentativas, o nível do jogo e o número mistério dentro do intervalo do nível escolhido. No caso de ser automático deve usar-se a função rand para se gerar os números pseudo-aleatórios. A função rand gera sempre a mesma sequência de números aleatórios dependente da semente que esteja definida. Isto é, para a mesma semente a sequência de números gerados é sempre a mesma. Este comportamento é útil quando se quer comparar algoritmos diferentes com os mesmos valores aleatórios. Para se gerar uma nova semente usa-se a função srand. Assim, os alunos devem chamar a função srand no main para obter uma nova semente (a partir dos últimos bits do relógio como está mostrado abaixo), e usar a rand para obter um valor entre MIN e MAX usando o que está mostrado em baixo. Não esquecer de incluir os ficheiros de declaração necessários. Para mais esclarecimentos consulte o livro (pág. 221). #include <stdlib.h> #include <time.h> srand (time(null)); numero_misterio = (rand () % (MAX MIN + 1)) + MIN; Depois da fase de preparação, o programa deve limpar o ecrã no caso da escolha ter sido manual, e escrever o nível do jogo (também com o intervalo de valores possível) e o número máximo de tentativas. 5
6 A seguir começa a fase de execução do jogo em que a cada tentativa do jogador o programa deve indicar se o número mistério está para cima ou para baixo do valor introduzido e também o número de tentativa que faltam. 4.2 VALORES POSSÍVEIS Existem três níveis de jogo: Nível 1: número mistério entre 1 e 100 Nível 2: número mistério entre 1 e 1000 Nível 3: número mistério entre 1 e Existem três valores para o número máximo de tentativas: Tentativas 1: 10 Tentativas 2: 15 Tentativas 3: OBRIGATORIEDADE Os alunos têm obrigatoriamente que obedecer às seguinte indicações 1. A função main é muito pequena e quase que só faz chamadas a funções. Pode conter apenas alguma (ou algumas) instrução if fundamental. 2. Devem existir os menus suficientes para informar os utilizadores do que é preciso ele introduzir (fora da main). As funções desses menus podem ser elas mesmas a ler os valores introduzidos pelo utilizador. 3. Cada opção dos valores a introduzir (nível, tentativas, mistério) é executada numa função própria para essa opção. 4. Existe APENAS uma função que executa a escolha de um número mistério entre MIN e MAX. Essa função será utilizada para os vários propósitos (nível, tentativas, mistério). 5. Repare que malgrado ser sorteio ou escolha por um utilizador, o jogo é o mesmo, e deve haver apenas uma função chamada jogo. Um exemplo para o programa no caso de sorteio está mostrado na página seguinte (para o caso manual as alterações são óbvias): 6
7 /********* JOGO DO SOBE E DESCE **************/ Valores por sorteio (1) ou manuais (2): 4 Erro na introdução de dados. Valores por sorteio (1) ou manuais (2): 1 Estamos a jogar com o nível 2 (1 a 1000) e com um máximo de tentativas de 20. Diga um número: 50 O numero mistério está abaixo. Ainda tem 19 tentativas. Diga um numero: 30 Parabéns! Acertou em 2 tentativas Quer jogar outra vez (s ou n): n Adeus. 7
PROGRAMAÇÃO DE MICROPROCESSADORES 2009 / 2010
Departamento de Engenharia Electrotécnica PROGRAMAÇÃO DE MICROPROCESSADORES 2009 / 2010 Mestrado Integrado em Engenharia Electrotécnica e Computadores 1º ano 2º semestre Trabalho nº 5 Funções e Vectores
PROGRAMAÇÃO DE MICROPROCESSADORES 2009 / 2010
Departamento de Engenharia Electrotécnica PROGRAMAÇÃO DE MICROPROCESSADORES 2009 / 2010 Mestrado Integrado em Engenharia Electrotécnica e Computadores 1º ano 2º semestre Trabalho nº 3 Testes, condições
PROGRAMAÇÃO DE MICROPROCESSADORES 2007 / 2008
Departamento de Engenharia Electrotécnica PROGRAMAÇÃO DE MICROPROCESSADORES 2007 / 2008 Mestrado Integrado em Engenharia Electrotécnica e Computadores 1º ano 1º semestre Testes, condições e ciclos http://tele1.dee.fct.unl.pt
1 Exercícios com ponteiros
Computação para Informática - Prof. Adriano Joaquim de Oliveira Cruz Oitava Aula Prática - 29 de outubro de 2010 O objetivo desta aula prática é exercitar ponteiros e funções. 1 Exercícios com ponteiros
Algoritmos e Programação
Algoritmos e Programação Aula 9 Subalgoritmos, funções e passagem de parâmetros Profa. Marina Gomes [email protected] 22/06/2017 Engenharia de Computação - Unipampa 1 Modularização Facilita a
1 Exercícios com ponteiros
Computação para Informática Funções e Ponteiros1 EXERCÍCIOS COM PONTEIROS Computação para Informática - Prof. Adriano Joaquim de Oliveira Cruz Aula Prática - Funções e ponteiros O objetivo desta aula prática
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;
Programação. Folha Prática 5. Lab. 5. Departamento de Informática Universidade da Beira Interior Portugal Copyright 2010 All rights reserved.
Programação Folha Prática 5 Lab. 5 Departamento de Informática Universidade da Beira Interior Portugal 2015 Copyright 2010 All rights reserved. 1. Revisão. 2. Objectivos. 3. Exercícios LAB. 5 5ª semana
Introdução à Programação em C Input / Output
Introdução à Programação em C Input / Output Resumo Aula Anterior Programa começa com função main() Sintaxe para definição de funções Definição de variáveis e atribuições Estruturas de controlo if-then
ESCOLA SUPERIOR DE TECNOLOGIA DE TOMAR DEPARTAMENTO DE ENGENHARIA INFORMÁTICA 2006/2007
ESCOLA SUPERIOR DE TECNOLOGIA DE TOMAR DEPARTAMENTO DE ENGENHARIA INFORMÁTICA INTRODUÇÃO À PROGRAMAÇÃO (ENG. INFORMÁTICA) COMPUTADORES E PROGRAMAÇÃO I (ENG. ELECTROTÉCNICA) 2006/2007 TRABALHO PRÁTICO Nº
3. Vectores: Algoritmos de Pesquisa. João Pascoal Faria (versão original) Ana Paula Rocha (versão 2004/2005) Luís Paulo Reis (versão 2005/2006)
3. Vectores: Algoritmos de Pesquisa João Pascoal Faria (versão original) Ana Paula Rocha (versão 2004/2005) Luís Paulo Reis (versão 2005/2006) FEUP - MIEEC Prog2-2006/2007 Introdução Algoritmo: conjunto
Linguagem de Programação I. Aula 10 Funções
Linguagem de Programação I Aula 10 Funções Da Aula Anterior Tipos de dados básicos e operadores em C Declaração de variáveis e modificadores de tipo Estruturas de Controle Arrays unidimensionais Geração
UNIVERSIDADE DA BEIRA INTERIOR
UNIVERSIDADE DA BEIRA INTERIOR Programação MIEA 1º Semestre Frequência Resolução 13/12/2016 1. Escreva uma expressão lógica em linguagem C para cada uma das seguintes condições: (a) o valor da variável
Computação e Programação Exame Época de recurso
Nome : Número : Computação e Programação 2013-2014 Mestrado Integrado em Engenharia Civil Licenciatura Bolonha em Engenharia Geológica e de Minas DECivil Exame Época de recurso 29 de Janeiro de 2014 v
PROGRAMAÇÃO INSTRUÇÕES DA LINGUAGEM C
PROGRAMAÇÃO INSTRUÇÕES DA LINGUAGEM C 1 Instruções de Entrada Entrada/Leitura de dados Introduzir um valor inteiro/real para X 2 Instruções de Entrada Entrada/Leitura de dados Introduzir um valor inteiro/real
PROGRAMAÇÃO FUNÇÕES NA LINGUAGEM C
PROGRAMAÇÃO FUNÇÕES NA LINGUAGEM C 1 Implementações básicas: a) Implementar o procedimento LerMatriz que preenche uma matriz de L linhas por C colunas de inteiros (L, C 1); b) Implementar o procedimento
PROGRAMAÇÃO DE COMPUTADORES V - TCC Modulo 6 : Funções Escopo de Variáveis: Globais x Locais Aura - Erick
PROGRAMAÇÃO DE COMPUTADORES V - TCC- 00.323 Modulo 6 : Funções Escopo de Variáveis: Globais x Locais Aura - Erick [email protected], [email protected] Roteiro Funções Escopo de Variáveis Variáveis Globais
Programação em C. Variáveis e Expressões. Universidade Federal do Rio Grande do Norte Departamento de Engenharia de Computação e Automação
Universidade Federal do Rio Grande do Norte Departamento de Engenharia de Computação e Automação Programação em C Variáveis e Expressões DCA0800 Algoritmos e Lógica de Programação Heitor Medeiros Florencio
Programação: Vetores
Programação de Computadores I Aula 09 Programação: Vetores José Romildo Malaquias Departamento de Computação Universidade Federal de Ouro Preto 2011-1 1/62 Motivação Problema Faça um programa que leia
Aula 6 Oficina de Programação Estruturas Condicionais no C. Profa. Elaine Faria UFU
Aula 6 Oficina de Programação Estruturas Condicionais no C Profa. Elaine Faria UFU - 2017 Estrutura Condicional Simples Algoritmo se () entao instrução fimse A instrução só será executada se
Conhecendo a Linguagem de Programação C
Universidade Federal do Rio Grande do Norte Departamento de Engenharia de Computação e Automação Conhecendo a Linguagem de Programação C DCA0800 - Algoritmos e Lógica de Programação Heitor Medeiros 1 Como
Programação. Folha Prática 6. Lab. 6. Departamento de Informática Universidade da Beira Interior Portugal. Copyright 2010 All rights reserved.
Programação Folha Prática 6 Lab. 6 Departamento de Informática Universidade da Beira Interior Portugal Copyright 2010 All rights reserved. 1. Revisão. 2. Objectivos. 3. Exercícios LAB. 6 6ª semana SUBPROGRAMAS
PROGRAMAÇÃO INSTRUÇÕES DA LINGUAGEM C
PROGRAMAÇÃO INSTRUÇÕES DA LINGUAGEM C 1 2 Condicional 1 Se 'C' é verdadeira Então?; 3 Condicional 1 Se 'C' é verdadeira Então? if (C)?; 4 Condicional 2 Se 'C' é verdadeira Então? Senão?? 5 Condicional
#include <stdio.h> main() { int i; // Cabeçalho for (i = 1; i <=20; i++) putchar( * ); putchar( \n ); puts( Numeros entre 1 e 5 );
O todo é igual à soma das partes. Euclides. FUNÇÕES E PROCEDIMENTOS Embora sem saber, ao longo dos outros laboratórios, já foram utilizadas funções tais como printf, scanf, getchar, putchar, dentre outras
Aula 15 - Aula sobre Funções e Procedimentos
MC-102 Algoritmos e Programação de Computadores IC-UNICAMP Aula 15 - Aula sobre Funções e Procedimentos 1 Objetivos Apresentar os conceitos de procedimentos e funções, suas vantagens e sua notação em C.
Linguagem C: Introdução
Linguagem C: Introdução Linguagem C É uma Linguagem de programação genérica que é utilizada para a criação de programas diversos como: Processadores de texto Planilhas eletrônicas Sistemas operacionais
ALGORITMOS E ESRUTRA DE DADOS I. Ponteiros Passagem por Valor e Referência Alocação de Memória
ALGORITMOS E ESRUTRA DE DADOS I Ponteiros Passagem por Valor e Referência Alocação de Memória 2 Agenda Ponteiros Conceitos gerais O que é Ponteiro? Declaração de Ponteiros Operadores para Ponteiros Exemplos
PROGRAMAÇÃO DE MICROPROCESSADORES 2007 / 2008
Departamento de Engenharia Electrotécnica PROGRAMAÇÃO DE MICROPROCESSADORES 2007 / 2008 Mestrado Integrado em Engenharia Electrotécnica e Computadores 1º ano 1º semestre Ficheiros e estruturas http://tele1.dee.fct.unl.pt
Nome: Número: Computação e Programação Mestrado Integrado em Engenharia Civil Licenciatura Bolonha em Engenharia Geológica e de Minas
Nome: Número: Computação e Programação 2017-2018 Mestrado Integrado em Engenharia Civil Licenciatura Bolonha em Engenharia Geológica e de Minas DECivil Exame Época Normal 10 de janeiro de 2018 Exame sem
12 - Dados Estruturados Vetores, Matrizes e Strings
12 - Dados Estruturados Vetores, Matrizes e Strings Unesp Campus de Guaratinguetá Curso de Programação Computadores Prof. Aníbal Tavares Profa. Cassilda Ribeiro Ministrado por: Prof. André Amarante Vetores,
Modularidade - Funções e Procedimentos
Modularidade - Funções e Procedimentos José Gustavo de Souza Paiva Problema Em diversas situações, é preciso executar uma tarefa específica diversas vezes em um programa, variando apenas os dados de entrada
Programação Básica. Estrutura de um algoritmo
Programação Básica Estrutura de um algoritmo Código-fonte Como vimos na aula anterior um algoritmo pode ser representado usando um fluxograma Um algoritmo pode também ser representado usando texto Esse
ALGORITMOS AULA 01. Baseado nas aulas do Prof. Jorgiano Vidal
ALGORITMOS AULA 01 Baseado nas aulas do Prof. Jorgiano Vidal LINGUAGEM C Uma das grandes vantagens do C é que ele possui tanto caracterìsticas de "alto nìvel" quanto de "baixo nìvel". Linguagem de propósito
Para cada programa, por mais simples que seja, comece sempre por esboçar a solução desenhando um fluxograma.
Instruções de Repetição Objetivo A realização deste trabalho deverá permitir ao aluno a familiarização com a utilização de instruções de repetição em C. Para o efeito será proposto um conjunto de exercícios
Faculdade de Computação
Faculdade de Computação Programação Procedimental 1 o Laboratório de Programação C Prof. Cláudio C. Rodrigues 1. Introdução O objetivo desta aula prática é exercitar o uso de variáveis de vários tipos
1, caso haja uma mina na posição (i, j),
MAC 2166 Introdução à Ciência da Computação Primeiro Semestre de 2017 Terceiro Exercício-Programa: Busca minas Muitos de vocês devem conhecer o jogo do campo minado. Existem implementações para o Windows
Linguagem C (estruturas condicionais)
Linguagem C (estruturas condicionais) André Tavares da Silva [email protected] Comandos de Controle de Fluxo Todos os comandos devem ser terminados com um ;. { e são usados para delimitar um
Programação 1. Atribuição, operadores aritméticos, entrada de dados. Técnico em Eletrônica Semestre 5 02
Programação 1 Atribuição, operadores aritméticos, entrada de dados Técnico em Eletrônica Semestre 5 02 Armazenando na memória tipo de variável #include #include main() { int ano; Declaração
Modulo 4: while do while (limites de variáveis)
PROGRAMAÇÃO DE COMPUTADORES V - TCC- 00.323 Modulo 4: while do while (limites de variáveis) Aura - Erick [email protected], [email protected] Roteiro Até aqui apreendemos as estruturas: If e If...else Switch
C Comandos de Controle
C Comandos de Controle Adriano Cruz [email protected] 19 de julho de 2017 Instituto de Matemática Departamento de Ciência da Computação UFRJ 1 Revisão da Seção Introdução Comandos de Teste Comandos de
Programação Mestrado Integrado em Engenharia Aeronáutica 1º ano, 1º semestre. T. 04 Algoritmos e Programação Estruturada
Programação Mestrado Integrado em Engenharia Aeronáutica 1º ano, 1º semestre T. 04 Algoritmos e Programação Estruturada Objectivos: Aprender o conceito de algoritmo e suas características fundamentais
Sistemas Operacionais e Introdução à Programação. Programação com linguagem C
Sistemas Operacionais e Introdução à Programação Programação com linguagem C 1 Entrada e saída: escrevendo na tela Veja uma comparação entre um programa Portugol e seu equivalente em C: Inicio Inteiro
Unidade 2: Estruturas de Controle Parte 1 - Scanner e Estrutura IF Prof. Daniel Caetano
Linguagem de Programação 1 Unidade 2: Estruturas de Controle Parte 1 - Scanner e Estrutura IF Prof. Daniel Caetano Objetivo: Apresentar a classe Scanner e as principais estruturas de controle da linguagem
Introdução à Linguagem de Programação C: Variáveis, Constantes, Expressões, Atribuição, Tipos de dados, Entrada e Saída de Dados
Introdução à Linguagem de Programação C: Variáveis, Constantes, Expressões, Atribuição, Tipos de dados, Entrada e Saída de Dados Disciplina de Programação de Computadores I Universidade Federal de Ouro
Ponteiros e Tabelas. K&R: Capítulo 5
Ponteiros e Tabelas K&R: Capítulo 5 Ponteiros e Tabelas Ponteiros e endereços Ponteiros e argumentos de funções Ponteiros e tabelas Alocação dinâmica de memória Aritmética de ponteiros Tabelas de ponteiros
Lógica e Linguagem de Programação Convertendo um algoritmo em pseudocódigo para a linguagem C Professor: Danilo Giacobo
Lógica e Linguagem de Programação Convertendo um algoritmo em pseudocódigo para a linguagem C Professor: Danilo Giacobo Este documento explica como transformar um algoritmo escrito na forma pseudocódigo
Conceito de procedimentos e funções
Tópicos Introdução Como funcionam as funções Declaração de funções Exemplo de funções 1 Introdução As funções, são unidades de código desenhadas para cumprir uma determinada tarefa. Até agora, já utilizamos
Sistemas Operacionais e Introdução à Programação. Introdução à Lógica de Programação: estruturas de repetição
Sistemas Operacionais e Introdução à Programação Introdução à Lógica de Programação: estruturas de repetição 1 Imagine um algoritmo para calcular a média de uma quantidade desconhecida de números Para
