Instituto Superior Politécnico de VISEU. Escola Superior de Tecnologia



Documentos relacionados
Informática II Cap. 3

Algoritmos: Lógica para desenvolvimento de programação de computadores. Autor: José Augusto Manzano. Capítulo 1 Abordagem Contextual

AULA TEÓRICA 10 Tema 9. Introdução à programação. Desenho de Algoritmos

INTRODUÇÃO ÀS LINGUAGENS DE PROGRAMAÇÃO

TECNOLOGIAS DA INFORMAÇÃO E COMUNICAÇÃO. SISTEMAS DE GESTÃO DE BASE DE DADOS Microsoft Access TECNOLOGIAS DA INFORMAÇÃO E COMUNICAÇÃO

TECNOLOGIAS DE INFORMAÇÃO E COMUNICAÇÃO

Introdução à Programação

Algoritmos não se aprendem: Copiando algoritmos Estudando algoritmos Algoritmos só se aprendem: Construindo algoritmos Testando algoritmos

Introdução a Informática. Prof.: Roberto Franciscatto

Análise de Sistemas. Conceito de análise de sistemas

Modelo Cascata ou Clássico

O que é um programa? Programa é uma lista de instruções que descrevem uma tarefa a ser realizada pelo computador.

Dadas a base e a altura de um triangulo, determinar sua área.

3. O NIVEL DA LINGUAGEM DE MONTAGEM

PROGRAMAÇÃO JAVA. Parte 1

Gestão do Risco e da Qualidade no Desenvolvimento de Software

A lógica de programação ajuda a facilitar o desenvolvimento dos futuros programas que você desenvolverá.

1. NÍVEL CONVENCIONAL DE MÁQUINA

Prototipagem em Papel Desenvolver e testar interfaces antes de iniciar a programação. Ivo Gomes

COTAÇÕES GRUPO I pontos pontos pontos pontos pontos pontos GRUPO II

Introdução às Linguagens de Programação

1.1. Organização de um Sistema Computacional

Orientação a Objetos

ICC Introdução para JavaScript

Um compilador é um programa que lê um programa escrito numa dada linguagem, a linguagem objecto (fonte), e a traduz num programa equivalente

A apresentação através de fluxos lógicos consegue mostrar mal entendidos e pontos que são controversos.

COMPILADORES E INTERPRETADORES

Algoritmos e Programação (Prática) Profa. Andreza Leite andreza.leite@univasf.edu.br

3 Sistemas de Numeração:

Introdução à Lógica de Programação

1. Introdução ao uso da calculadora

Programa de Unidade Curricular

Curso Técnico em Redes

CURSO: TÉCNICO EM INFORMÁTICA NA MODALIDADE EAD

Invenções Implementadas por Computador (IIC) Patentes

TÉCNICAS DE PROGRAMAÇÃO

CONCEITOS BÁSICOS DE UM SISTEMA OPERATIVO

AMBIENTE PARA AUXILIAR O DESENVOLVIMENTO DE PROGRAMAS MONOLÍTICOS

SISTEMAS DE INFORMAÇÃO PARA GESTÃO

AMBIENTE DE PROGRAMAÇÃO PYTHON

Tecnologia da Informação. Visão Geral sobre Informática

CAP. I ERROS EM CÁLCULO NUMÉRICO

UNIVERSIDADE FEDERAL DO PARANÁ UFPR Bacharelado em Ciência da Computação

Introdução à Programação de Computadores

Wilson Moraes Góes. Novatec

Metodologias de Desenvolvimento de Sistemas. Analise de Sistemas I UNIPAC Rodrigo Videschi

PROCESSO DE DESENVOLVIMENTO DE SOFTWARE. Modelos de Processo de Desenvolvimento de Software

ENGENHARIA DE SOFTWARE

PLANIFICAÇÃO MODULAR

PROGRAMAÇÃO DE MICROPROCESSADORES 2011 / 2012

Module Introduction. Programação. Cap. 4 Algoritmos e Programação Estruturada

Resolução de problemas e desenvolvimento de algoritmos

Autómatos Finitos Determinísticos

Lição 1 Introdução à programação de computadores

Metodos de Programação

Aula 10 Introdução à Algoritmos. Disciplina: Fundamentos de Lógica e Algoritmos Prof. Bruno Gomes

Unidade VI. Validação e Verificação de Software Teste de Software. Conteúdo. Técnicas de Teste. Estratégias de Teste

Projeto de Sistemas I

BIBLIOTECA ESCOLAR CENTRO DE RECURSOS EDUCATIVOS COMO FAZER UM TRABALHO DE PESQUISA

Programação I. Departamento de Engenharia Rural Centro de Ciências Agrárias

TIC Unidade 2 Base de Dados. Informação é todo o conjunto de dados devidamente ordenados e organizados de forma a terem significado.

AULA 4 VISÃO BÁSICA DE CLASSES EM PHP

Orientação a Objetos

ISO 9001:2008. A International Organization for Standardization (ISO) publicou em a nova edição da Norma ISO 9000:

PONTIFÍCIA UNIVERSIDADE CATÓLICA DE GOIÁS Curso Superior de Tecnologia em Análise e Desenvolvimento de Sistemas

OFICIAL DA ORDEM MILITAR DE CRISTO MEDALHA DE EDUCAÇÃO FÍSICA E BONS SERVIÇOS. Circular n.º 029/2014 PORTAL FPT Abertura aos atletas

Geração de código intermediário. Novembro 2006

Sistemas Operacionais

Cap.2.5: Design de Algoritmos e Programação Estruturada. Algoritmos, fluxogramas e pseudo-código

Prof. Dr. Abel Gomes Cap.4: Design de Algoritmos e Programação Estruturada. Algoritmos, fluxogramas e pseudo-código

Implementando uma Classe e Criando Objetos a partir dela

Figura 1 - O computador

Informática Aplicada à Engenharia Florestal

Como melhorar a Qualidade de Software através s de testes e nua. Cláudio Antônio de Araújo 22/11/2008

Processamento da Informação Teoria. Algoritmos e Tipos de dados

Desenvolvimento de Interfaces Prototipação

ARQUITETURA DE COMPUTADORES. Rogério Spindula Rosa

2. ALGORITMOS. Unesp Campus de Guaratinguetá. Curso de Programação Computadores Prof. Aníbal Tavares Profa. Cassilda Ribeiro

Programação de Computadores I Fluxogramas PROFESSORA CINTIA CAETANO

Algoritmos. Cláudio Barbosa

Introdução. A Informação e sua Representação (Parte III) Universidade Federal de Campina Grande Departamento de Sistemas e Computação

Na medida em que se cria um produto, o sistema de software, que será usado e mantido, nos aproximamos da engenharia.

Nome COMPLETO: Nº: Leia atentamente as notas que se seguem. Só depois deve iniciar o exame.

UNIDADE 6 - PROGRAMAÇÃO MODULAR

ALP Algoritmos e Programação. . Linguagens para Computadores

Análise e Desenvolvimento de Sistemas ADS Programação Orientada a Obejeto POO 3º Semestre AULA 03 - INTRODUÇÃO À PROGRAMAÇÃO ORIENTADA A OBJETO (POO)

GereComSaber. Disciplina de Desenvolvimento de Sistemas de Software. Sistema de Gestão de Serviços em Condomínios

ARQUITECTURA DE COMPUTADORES CAPÍTULO II AULA X

Pragmática das Linguagens de Programação 2004/2005

Capítulo 1. Linguagens e processadores

Algoritmos e Programação Estruturada

GIAE VERSÃO JUNHO DE 2011 MUITO IMPORTANTE

Algoritmos com VisuAlg

Departamento de Informática

ROTEIRO PARA ELABORAÇÃO DE PROJETOS

Interface Pessoa Máquina

Transcrição:

1

Tradicionalmente, programar significava apenas a escrita de um programa, que resolvesse o problema pretendido de uma forma aparentemente correcta. Problema Problema Programa Programa Desvantagens: Programas pouco claros e pouco eficientes. Algumas vezes, programas formalmente incorrectos. Dificuldade de converter o programa para outra linguagem de programação. Necessidade de adoptar uma nova metodologia de resolução de problemas. Realizar uma passagem progressiva do problema ao programa, de maneira a evitar todos os inconvenientes anteriormente apontados. 2

Vantagens: Programa mais claro e eficiente. Programa formalmente correcto (ausência de erros lógicos). Fácil de converter para qualquer linguagem de programação, pois é praticamente independente da linguagem de programação. 3

Análise Objectivo: compreensão e a descrição do problema proposto. No caso de resolução de problemas simples, as questões essenciais prendem-se com a determinação e especificação dos seguintes pontos: Com que dados vamos trabalhar Entradas. Que resultados devemos obter Saídas. Que processos devemos utilizar para produzir resultados Definição do problema. A fase de Análise torna-se particularmente relevante quando estamos perante problemas complexos. Nestes casos utiliza-se a técnica de decomposição de um problema em subproblemas mais simples. 4

Elaboração de um Algoritmo Como sabemos, um um computador não não resolve problemas sozinho, apenas executa os os passos que que lhe lhe indicamos para para a sua sua resolução. Em Em informática, a formulação de de um um algoritmo não não é mais mais do do que que a descrição, de de forma ordenada, com com clareza e rigor, das das operações que que se se pretende realizar num num computador para para resolver um um problema ou ou atingir determinados objectivos. Um Um bom bom algoritmo, pode pode ser ser escrito na na nossa linguagem natural, utilizando expressões sintéticas e exactas e, e, normalmente, também alguns sinais convencionais. O algoritmo deve deve ser ser formulado de de modo a poder ser ser traduzido numa qualquer linguagem de de programação. 5

Formas de apresentação de algoritmos para computador As As formas mais mais divulgadas para para representação de de algoritmos num num computador são: são: Fluxogramas Pseudocódigo 6

Fluxogramas Os Os fluxogramas são são diagramas representativos do do fluxo das das acções de de um um programa, através de de símbolos, que que representam os os diferentes tipos tipos das das acções e o seu seu encadeamento na na sequência do do programa. Actualmente, os os fluxogramas não não são são muito utilizados. Eles Eles têm têm algum interesse mais mais do do ponto de de vista vista didáctico do do que que na na prática de de programação. Podem ser ser úteis úteis para para visualizar melhor determinadas estruturas de de programação. Para Para representar programas de de média ou ou grande extensão, tornam-se difíceis de de concretizar podem exigir muito espaço, para para além além do do tamanho habitual de de uma uma folha folha de de papel, o que que os os torna tornade dedifícil leitura e manuseamento. 7

Pseudocódigo Por Por pseudocódigo entende-se um um código de de escrita em em que que se se utilizam, usualmente, um um misto de de palavras da da nossa linguagem natural com com palavras e notações típicas das das linguagens de de programação. O pseudocódigo tem-se revelado mais mais prático e mais mais vantajoso na na estruturação do do raciocínio e dos dos elementos (acções, dados) a incluir num num programa. 8

Codificação e Depuração Após formulado o algoritmo, há há que que transcrevê-lo para para a linguagem de de programação, que que se se pretende utilizar trata-se da da operação de de codificação ou ou escrita do do programa --fonte ou ou código fonte. Depois de de termos pronto o programa fonte, para para que que ele ele possa ser ser executado, como já jásabemos, é necessário utilizar software de de tradução (compilador ou ou interpretador), que que irá iráconverter o código fonte fonte para para código máquina. Mas, Mas, antes antes de de darmos o programa por por concluído, ainda poderemos ter ter que que fazer alguns testes de de verificação e eventuais correcções. Antes de de mais mais há há que que verificar se se ele ele está estáescrito correctamente de de acordo com com as as normas impostas pela pela linguagem.; se se houver erros de de escrita, o compilador ou ou o interpretador não não os os deixará passar, o programa não não poderá correr e seremos obrigados a proceder a uma uma revisão do do texto, para para rectificar esses esses mesmos erros. 9

Codificação e Depuração Para Para além além disso, mesmo depois de de o programa passar no no teste teste de de verificação do do compilador ou ou do do interpretador, pode pode muito bem bem acontecer que que tenha falhas do do ponto de de vista vista lógico ou ou de de coerência com com os os objectivos que que se se pretendem alcançar por por imprecisões, deficiente definição algorítmica, vícios de de raciocínio, etc. etc. Há Háentão que que testar o programa, com com dados diversificados e com com diferentes utilizadores; se se houver algum imprevisto, pode pode exigir alterações na na implementação do do programa. A fase fase de de correcção de de erros, quer quer de de sintaxe, quer quer de de concepção lógica chamase depuração. se 10

Programação Estruturada O modelo da programação estruturada surgiu da necessidade de obter programas simples e claros, de fácil manutenção e actualização. As teorias de programação actuais centram-se nas técnicas de programação modular e de programação estruturada. A programação modular é um método de desenho que considera a decomposição de um problema em partes independentes, bem diferenciados logicamente. A programação estruturada é complementar da programação modular, pois enquanto que esta procura dividir u programa em partes mais pequenas, aquela desenvolve estruturalmente cada um dos módulos. 11