Algoritmos e Técnicas de Programação

Documentos relacionados
Introdução à Programação

Aula 5 Oficina de Programação Introdução ao C. Profa. Elaine Faria UFU

ponteiros INF Programação I Prof. Roberto Azevedo

Introdução à Computação

Noções de Algoritmos

Pseudocódigo e Visualg

Conceitos Básicos. Professor: Juliano Lucas Gonçalves.

PROGRAMAÇÃO de COMPUTADORES: LINGUAGEM FORTRAN 90/95

É neste ponto que entra o conceito de lógica de programação.

Capítulo 4: Condicionais

Introdução a Computação

Fundamentos de Programação

A única diferença entre o difícil e o impossível é que o último demora um pouco mais de tempo para ser alcançado..

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

Algoritmos e Programação. Ederson Luiz da Silva Ciência da Computação

Algoritmos e Programação - Engenharia da Computação -

Programação Básica. Estrutura de um algoritmo

Aula 05: Condicionais (if / else)

Algoritmos e Programação

Programação Básica de Computadores

ALGORITMOS CONCEITOS PRELIMINARES. Prof. Angelo Augusto Frozza, M.Sc.

Introdução à Programação Estruturada Parte 3. Material da Prof. Ana Eliza

3. Linguagem de Programação C

Lógica e Linguagem de Programação Convertendo um algoritmo em pseudocódigo para a linguagem C Professor: Danilo Giacobo

Aula 12- Variáveis e valores reais

Conhecendo a Linguagem de Programação C

Algoritmos RESUMO - LINGUAGEM C

Algoritmos e Técnicas de Programação. Professora: Luciana Faria

Algoritmos e Técnicas de Programação

Introdução à Programação

Aula 1 - Introdução Cleverton Hentz

BCC Introdu c ao ` a Programa c ao Portugol Guillermo C amara-ch avez UFOP 1/35

Lógica de Programação Atividade Avaliativa 1 RESPOSTAS

LÓGICA DE PROGRAMAÇÃO. Algoritmos Computacionais. Sérgio Carlos Portari Júnior

Linguagem de Programação

Capítulo 1: Introdução à Linguagem C. Pontifícia Universidade Católica Departamento de Informática

Aula 3: Algoritmos: Formalização e Construção

Conceitos Básicos de Programação

Algoritmos e Estruturas de Dados I (DCC/003) Introdução à Programação de Computadores. Aula - Tópico 1

ALGORITMO I ESTRUTURA DE CONTROLE DECISÃO SE / CASO;

CONCEITOS DE ALGORITMOS

controle de fluxo - condicionais

Introdução à Programação. Ceça Moraes

ALGORITMOS E ESRUTRA DE DADOS I. Ponteiros Passagem por Valor e Referência Alocação de Memória

Algoritmos e Estruturas de Dados I. Universidade Federal de São João del-rei Pedro Mitsuo Shiroma Sala 119 Bloco 3

Algoritmos: tipos de dados, variáveis e expressões

Programação 1. Atribuição, operadores aritméticos, entrada de dados. Técnico em Eletrônica Semestre 5 02

TÉCNICO DE INFORMÁTICA - SISTEMAS

CONCEITO DE ALGORITMO

Algoritmo. Prof. Anderson Almeida Ferreira. Agradeço ao prof. Guilherme Tavares de Assis por fornecer slides que fazem parte desta apresentação

Técnicas de Programação

Linguagem de Programação I Prof. Tiago Eugenio de Melo.

Introdução à Algoritmos INF 1005 e INF Programação I

Algoritmos e Técnicas. Lógica de Programação. É a técnica de encadear pensamento para atingir determinado objetivo.

Algoritmos. Para encontrar a raiz de uma equação quadrática, são necessários alguns passos detalhados:

Programação em C. Victor Amorim dos Santos

Comandos de desvio de fluxo. Expressões lógicas.

Curso de C. Introdução by Arnaldo V. Moura e Daniel F. Ferber 3/10/ :43 AM

Linguagens de Programação

Transcrição:

Algoritmos e Técnicas de Programação Introdução a Algoritmos Jonathan Pereira Jonathan.pereira@ifrn.edu.br

Sumário Introdução a algoritmos Linguagem de programação Elaboração de programas

Sumário Introdução a algoritmos Linguagem de programação Elaboração de programas

Algoritmo Definição Descrição de um conjunto finito de comandos para a solução de um problema em um tempo finito.

Algoritmo Exemplo :: Trocar o pneu de um carro

Algoritmo Exemplo :: Trocar o pneu de um carro 1. Desparafusar a roda.

Algoritmo Exemplo :: Trocar o pneu de um carro 2. Suspender o carro com um macaco.

Algoritmo Exemplo :: Trocar o pneu de um carro 3. Retirar a roda com o pneu furado.

Algoritmo Exemplo :: Trocar o pneu de um carro 4. Colocar o step.

Algoritmo Exemplo :: Trocar o pneu de um carro 5. Abaixar o carro.

Algoritmo Exemplo :: Trocar o pneu de um carro 6. Parafusar a roda.

Algoritmo Mais Exemplos Trocar uma lâmpada. Fazer um bolo. Fazer um barco de papel. p

Algoritmos... Conjunto de regras formais para a obtenção de um resultado ou da solução de um problema Forbellone & Eberspacher, 2000 Um processo sistemático para a solução de um determinado problema Szwarcfiter & Makenzon, 1994 Uma seqüência ordenada de passos a ser seguida para a realização de uma determinada tarefa Saliba, 1992 Conjunto finito de regras que fornece uma seqüência de operações para resolver um problema específico Algoritmo pode ser especificado de forma textual usando uma pseudolinguagem ou sob a forma de diagrama

Algoritmo Propriedades Possui um estado inicial Possui seqüência lógica Contém ações claras e precisas Possui dados de entrada Produz estado final previsível Deve ser eficaz

Algoritmo Fluxo Entrada Seqüência Lógica Saída

Algoritmo Fluxo Raio R de uma circunferência P=2*π*R Perímetro P da Perímetro P da circunferência

...Pseudolinguagem Portugol... Elementos t da linguagem Definição de variáveis nome dado a um local de memória reservado para armazenar valores possíveis do tipo de dado associado. Ex.: inteiro: K, J2, QTDIAS,... real: SALARIO, PRECO, TOTAL, X1,... caractere: NOME, ENDERECO, RUA,... logico: APROVADO, CHEIO, TEM,... Comando de atribuição atribui valor a uma variável Ex.: SALARIO 480.00 00, APROVADO FALSO, QTDIAS 36,... Operadores lógicos e (٨), ou (٧), não ( )

...Pseudolinguagem Portugol... Elementos da linguagem Operadores aritméticos +, -, *, /,, sen(x), (), cos(x), mod, div,(a + b) n, Operadores relacionais - =,, ou >=, ou <= Prioridade das operações parênteses

...Pseudolinguagem Portugol Elementos da linguagem Entrada leia (A, B, C); Saída imprima (A, B, C); Exemplo de algoritmo em Portugol: inicio inteiro: A, B; A 1; B 2; se A>Bentão A 5; senão A 10; fim se; fim.

Sumário Revisão de algoritmos Linguagem de programação Elaboração de programas

Linguagem de programação Estabelece regras de sintaxe para que o algoritmo possa ser entendido por uma máquina.

Algoritmo Linguagem de Programação Raciocínio Algoritmo int a, b, c; if (a > 2) a = b + c; else a = b c; return; Programa

Programa Programa é a codificação de um algoritmo em uma linguagem de programação. Um computador é uma máquina que, a partir de uma entrada, realiza um número de cálculos matemáticos e lógicos, gerando uma saída. Programa a a é o elemento e e que diz ao computador quais cálculos devem ser realizados.

Sumário Revisão de algoritmos Linguagem de programação Elaboração de programas

Passos para elaboração de um programa 1. Compreender o problema. 2. Esboçar um procedimento para resolver o problema. 3. Formular ua o algoritmo. ago o 4. Traduzir o algoritmo para uma linguagem de programação (Codificação).

Passos para elaboração de um programa :: Exemplo Calcular as raízes reais de: ax 2 + bx + c

1. Compreender o problema Exemplo: Equação de 2o. grau Possibilidades de raízes: 02 raízes complexas; 02 raízes reais idênticas; 02 raízes reais distintas; Condição ã para haver raízes reais: 0

2. Esboçar um procedimento para resolver o problema Calcular. Se 0, calcular raízes reais. Caso contrário, informar que não há raízes reais.

3. Formular o algoritmo ler(a,b,c) delta = b^2 4*a*c se (delta 0) então r1 = b (delta)^( 1/2) r2 = b + (delta)^( 1/2) escrever(r1,r2) senão escrever( Não (Não há raiz real ) fim do se fim do algoritmo

4. Codificar #include <stdio.h> #include <stdlib.h> #include <math.h> int main(void) { float a, b, c, delta, r1, r2; scanf("%f %f %f", &a, &b, &c); delta = b*b 4*a*c; * if (delta >= 0) { r1 = b sqrt(delta); r2 = b + sqrt(delta); printf("r1 = %f \n r2 = %f", r1, r2); } else printf("nao ha raiz real\n" n"); }

Gerando um programa executável Passos necessários para gerar um programa executável: A. Codificação B. Geração de Código Objeto C. Linkagem D. Depuração (debug)

Gerando um programa executável Codificação Código fonte Código objeto Geração de código objeto Depuração Bibliotecas Linkagem Programa Executável

Gerando um programa executável A. Codificação É É a escrita de um programa de acordo com uma linguagem de programação. Utiliza Editores de Texto. Resultado: código-fonte fonte.

Gerando um programa executável B. Geração de código-objeto objeto Tradução do código-fonte para o código de máquina do processador. Realizado pelos Compiladores. Resultado: código-objeto objeto.

Gerando um programa executável C. Linkagem Rearranja o código do programa Incorpora as partes referenciadas no código original (obtidas de uma biblioteca). Realizada pelos Ligadores. Resultado: código executável pelo processador.