Algoritmos e Linguagem de Programação de Computadores I



Documentos relacionados
Estrutura de Dados. Ricardo José Cabeça de Souza Parte 1

Ricardo José Cabeça de Souza.

CURSO DE INFORMÁTICA. Algoritmos. Parte 4. Ricardo José Cabeça de Souza

FACULDADE PITÁGORAS DISCIPLINA: ARQUITETURA DE COMPUTADORES

Introdução. INF1005 Programação I 33K Prof. Gustavo Moreira gmoreira@inf.puc-rio.br

LÓGICA DE PROGRAMAÇÃO

CURSO DE INFORMÁTICA. Algoritmos. Parte 3. Ricardo José Cabeça de Souza

1.1. Organização de um Sistema Computacional

Organização de Computadores

PROCESSAMENTO DE DADOS

INFORMÁTICA BÁSICA. Prof. Rafael Zimmermann

Programação de Computadores

Apostila de Fundamentos de Programação I. Prof.: André Luiz Montevecchi

Algoritmos. Cláudio Barbosa

ALGORITMOS E TÉCNICAS DE PROGRAMAÇÃO

Memória principal; Unidade de Controle U C P. Unidade Lógica e Aritmética

1 - Processamento de dados

1 Modelo de computador

Introdução à Programação 2006/07. Computadores e Programação

Introdução aos Computadores

ARQUITETURA DE COMPUTADORES

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

Capacidade = 512 x 300 x x 2 x 5 = ,72 GB

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

Introdução à Programação de Computadores

Estrutura de um Computador. Linguagem de Programação Rone Ilídio UFSJ - CAP

Programação Engenharia Informática (11543) 1º ano, 1º semestre Tecnologias e Sistemas de Informação (6619) 1º ano, 1º semestre

Prof. Dr. Charlie Antoni Miquelin BÁSICO DE COMPUTAÇÃO EM TC

Aula 01 Introdução à Informática. Prof. Bruno Gomes

Unidade Central de Processamento (CPU) Processador. Renan Manola Introdução ao Computador 2010/01

Estrutura geral de um computador

Curso de C. Introdução by Arnaldo V. Moura e Daniel F. Ferber

Capítulo I : Noções Gerais

Introdução à Programação e Algoritmos. Aécio Costa

UNIVERSIDADE FEDERAL DE UBERLÂNDIA Faculdade de Computação Curso de Introdução à Informática Prof: Anilton Joaquim da Silva / Ezequiel Roberto Zorzal

Figura 1 - O computador

ISL - Introdução. Sistema. Binário. Introdução. Tipos de Computador. Sub title text goes here. Unused Section Space 2. Unused Section Space 1

MC102 Algoritmos e Programação de Computadores 1ª Aula Introdução à Programação de Computadores

Informática. Prof. Macêdo Firmino. Macêdo Firmino (IFRN) Informática Setembro de / 25

Prof. Sandrina Correia

PRONATEC FUNDAMENTOS DE HARDWARE. Prof. Kilmer Pereira

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

Resolução de problemas e desenvolvimento de algoritmos

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

MANUTENÇÃO DE MICRO. Mário Gomes de Oliveira

Componentes de um computador típico

Aula 2 Modelo Simplificado de Computador

Sistemas Numéricos bit / Byte BIT BYTE. Prof. Celso Candido ADS / REDES / ENGENHARIA

Web site. Objetivos gerais. Introdução. Profa. Patrícia Dockhorn Costa

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

INFORMÁTICA - BICT (noturno)

Capítulo 2. Numéricos e Códigos Pearson Prentice Hall. Todos os direitos reservados.

Circuitos Digitais. Conteúdo. Sistema de Numeração e Códigos :: Conversões de Binário para Decimal SISTEMA DE NUMERAÇÃO E CÓDIGOS

Tecnologia da Informação. Prof Odilon Zappe Jr

Prof. Lázaro Nogueira

Lógica de Programação

Representação Binária de Dados

3. Arquitetura Básica do Computador

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

Programação para Computação

MC-102 Aula 01. Instituto de Computação Unicamp

AULA 1. Informática Básica. Gustavo Leitão. Disciplina: Professor:

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

Apostila Informática Básica. 1.0 Introdução 1/14

1. CAPÍTULO COMPUTADORES

Andrique Amorim INTRODUÇÃO A INFORMÁTICA

Apresentação. Rio de Janeiro, 19 de fevereiro de 2002 Waldemar Celes

Escola Secundária de Emídio Navarro

20/09/2009 TRANSFORMANDO DADOS EM. PROCESSANDO DADOS George Gomes Cabral SISTEMAS NUMÉRICOS INFORMAÇÕES

Disciplina: Organização de computadores

Informática, Internet e Multimídia

O processador é composto por: Unidade de controlo - Interpreta as instruções armazenadas; - Dá comandos a todos os elementos do sistema.

INF1004 e INF1005: Programação 1. Introdução à Programação

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

Escola Secundária de Emídio Navarro

Sistemas de Numeração

Programa A busca da formação integral de adolescentes que habitam as periferias e bolsões de miséria em Cascavel/PR através da saúde, do meio

CAPÍTULO 2 CARACTERÍSTICAS DE E/S E PORTA PARALELA

Disciplina: INTRODUÇÃO AOS SISTEMAS DE COMPUTAÇÃO Carga Horária: 68 (sessenta e oito) horas Crédítos: 04 (quatro)

Programação de Computadores I BCC 701. Introdução

CAPÍTULO 3 - TIPOS DE DADOS E IDENTIFICADORES

Sistemas de Computação

Algoritmos e Programação de Computadores I. Prof. Eduardo

LÓGICA DE PROGRAMAÇÃO PARA ENGENHARIA INTRODUÇÃO À ORGANIZAÇÃO DE COMPUTADORES

Áreas de aplicação das TIC

Fundamentos de Microinformática. Ricardo José Cabeça de Souza 2010 Fundamentos 3

Capítulo 2 Introdução à Programação Estrutura de Controle

SUMÁRIO. 6. FERRAMENTAS E APLICATIVOS ASSOCIADOS À INTERNET: navegação, correio eletrônico, grupos de discussão, busca e pesquisa...

Curso EFA Técnico/a de Informática - Sistemas. Óbidos

Sistemas Operacionais

Programação Estruturada

COMPUTADOR SIMPLIFICADO E COMPUTADOR DIGITAL. Algoritmos e Programação APG0001

O modelo do computador

Gerenciamento de Entrada e Saída Hélio Crestana Guardia e Hermes Senger

Escola Secundária c/3º CEB José Macedo Fragateiro. Curso Profissional de Nível Secundário. Componente Técnica. Disciplina de

Plano de Trabalho Docente Ensino Técnico

Informática. Técnico em Agronegócio 1º. Módulo Profa. Madalena Pereira da Silva

Introdução. Introdução. Introdução. Organização Estruturada de Computadores. Introdução. Máquinas Multiníveis

Introdução à Engenharia de Computação

Transcrição:

Algoritmos e Linguagem de Programação de Computadores I Ricardo José Cabeça de Souza www.ricardojcsouza.com.br

OBJETIVOS Apresentar conceitos básicos de algoritmos e sua importância na elaboração de soluções para resolver determinados problemas buscando implementação no computador

LÓGICA É a ciência das formas do pensamento Estuda a correção do reciocínio Visa a ordem da razão

DADO Conjunto de coisas organizadas por certo critério Utilizado para ser manipulado Pode ser: números, palavras, imagens, pessoas, etc. Possível de ser manipulado

INFORMAÇÃO Resultado da manipulação do dado Dado processado Necessita dos dados e de regras de manipulação

Processamento de Dados

AÇÃO Evento que ocorre em um período de tempo finito Estabelece um efeito Exemplo: Escrever uma carta, caminhar até um determinado local, etc.

COMPUTADOR Máquina composta por diversos elementos com a finalidade de manipular dados(símbolos). Recebe, armazena, efetua operações sobre os dados (aritméticas e lógicas), move, envia dados, com o objetivo de resolver problemas.

www.ricardojcsouza.com.br

MODELO DE UM COMPUTADOR CPU Central Processing Unit

MODELO DE UM COMPUTADOR O canal de comunicação (conhecido como BUS) Meio para a transferência de dados entre os diversos componentes Na memória principal São armazenados os programas e os dados no computador Tem acesso randômico, o que significa se pode endereçar (isto é, acessar) diretamente qualquer posição da memória Memória não é permanente(volátil) Dados são armazenados enquanto o programa está sendo executado Após o término do programa, a área ocupada na memória fica disponível para ser usada por outras aplicações

MODELO DE UM COMPUTADOR A área de armazenamento secundário Representada por um disco (disco rígido, pen driver, etc. Tem a vantagem de ser permanente Tem um custo mais baixo do que a memória principal Acesso aos dados é bem mais lento Dispositivos de entrada e saída Dispositivos de entrada (por exemplo, teclado, mouse) permitem passarmos dados para um programa Dispositivos de saída permitem que um programa exporte seus resultados, por exemplo em forma textual ou gráfica usando monitores ou impressoras

ARMAZENAMENTO DE DADOS E PROGRAMAS NA MEMÓRIA A memória do computador é dividida em unidades de armazenamento chamadas bytes Cada byte é composto por 8 bits, que podem armazenar os valores zero ou um Todas as informações (programas, textos, imagens, etc.) são armazenadas usando uma codificação numérica na forma binária Na representação binária, os números são representados por uma sequência de zeros e uns Por exemplo, o número decimal 5 é representado por 101, pois 1*2 2 + 0*2 1 + 1*2 0 é igual a 5 Não é possível endereçar diretamente um bit

ARMAZENAMENTO DE DADOS E PROGRAMAS NA MEMÓRIA Para ser possível armazenar uma sequência de caracteres, que representa o texto, atribui-se a cada caractere um código numérico Por exemplo, pode-se associar ao caractere 'A' o código 65, ao caractere 'B' o código 66, e assim por diante Se todos os caracteres tiverem códigos associados (inclusive os caracteres de pontuação e de formatação), podemos armazenar um texto na memória do computador como uma sequência de códigos numéricos

ARMAZENAMENTO DE DADOS E PROGRAMAS NA MEMÓRIA Um computador só pode executar programas em linguagens de máquina Cada programa executável é uma sequência de instruções que o processador central interpreta, executando as operações correspondentes Esta sequência de instruções também é representada como uma sequência de códigos numéricos Os programas ficam armazenados em disco e, para serem executados pelo computador, devem ser carregados (transferidos) para a memória principal Uma vez na memória, o computador executa a sequência de operações correspondente

HARDWARE Conjunto de dispositivos físicos que formam o computador Máquina propriamente dita

SOFTWARE Conjunto ordenado de instruções Expresso em linguagens especiais Compreensível pela máquina

BIT Representação binária Dois números: 0 e 1 Usado para representar os dados

BYTE Conjunto de oito bits Forma uma sequência para representar um dado Identifica um caractere 10100001 A 10100010 - B

ALGORITMO Sequência de passos a seguir para atingir determinado objetivo Características: Ser rigoroso regras Ser eficaz Resolver probleama Garantia de terminar finito

SINTAXE Regras que definem as relações válidas entre os componentes da linguagem

SEMÂNTICA Define o significado de cada frase na linguagem Análise do significado

LINGUAGEM DE PROGRAMAÇÃO Técnica de notação para programar Veículo para expressar um raciocínio Executar um algoritmo Programação: Estruturada Orientada a objetos Orientada a eventos

RESOLUÇÃO DE PROBLEMAS DEFINIÇÃO DO PROBLEMA Verificar o enunciado do problema Forma clara e completa Observar cuidadosamente sobre dúvidas Evitar interpretação ambígua

RESOLUÇÃO DE PROBLEMAS ANÁLISE DO PROBLEMA Três fases: Dados de entrada Dados Necessários para resolver problema Como resolver problema Fórmulas, regras, condições, etc. Dados de saída Resultado esperado

RESOLUÇÃO DE PROBLEMAS CONSTRUÇÃO DO MODELO Fluxograma Algoritmo

RESOLUÇÃO DE PROBLEMAS PROGRAMAÇÃO Transformação do modelo Usando linguagem programação Criação do código-fonte

RESOLUÇÃO DE PROBLEMAS EXECUÇÃO Submeter o programa ao computador Colocar na memória principal do computador Verificação erros: Sintaxe Semântica

RESOLUÇÃO DE PROBLEMAS DOCUMENTAÇÃO Inserir informações no código-fonte sobre a execução das operações Visa explicação dos passos a serem executados no programa Comentário

Referências TANENBAUM, Aaron M. Langsam, Yedidyah, Augenstein, Moshe J. Estruturas de dados usando C. São Paulo : MAKRON Books, 1995. VELOSO, Paulo. et. al. Estrutura de dados. Rio de Janeiro: Campus, 1986. MORAES, Celso Roberto. Estrutura de dados e algoritmos. 2. ed. São Paulo: Futura, 2003. CELES, W. Rangel, J. L. Curso de Estrutura de Dados. PUC-Rio, 2002. W. Celes, R. Cerqueira, J.L. Rangel. Introdução a Estruturas de Dados - com técnicas de programação em C. Rio de Janeiro: Campus, 2004. SCHILDT, Herbert. C Completo e total. São Paulo: MAKRON BOOKS, 1997. LOUDON, Kyle. Dominando algoritmos com C. São Paulo: CIENCIA MODERNA COMPUTAÇÃO, 2000. JAMSA, Kris. Programando em C/C++: a bíblia. São Paulo: Makron Books, 2000. LOPES, Anita. Introdução a programação: 500 algoritmos resolvidos. Rio de Janeiro: Campus, 2002. GIMARÃES, Ângelo de Moura. LAGES, Newton Alberto de Castilho. Algoritmos e estruturas de dados. Rio de Janeiro: Campus, 1985. LAUREANO, Marcos. Programando em C para Linux, Unix e Windows. Rio de Janeiro: BRASPORT LIVROS, 2005. MEDINA, Marco. FERTIG, Cristina. Algoritmos e programação: teoria e prática. São Paulo: NOVATEC INFORMATICA, 2005. ARAÚJO, Everton Coimbra de. Algoritmos: fundamentos e prática. 2. ed. Ampl. e atual. Florianópolis: VisualBooks, 2005. FEOFILOFF, Paulo. Projeto de Algoritmos em C. Disponível em http://www.ime.usp.br/~pf/algoritmos/aulas/lista.html acesso em 12/07/2011. HOLANDA, Aurélio Buarque. Dicionário Aurélio Eletrônico Século XX. Versão 3.0 Novembro, 1999.