Documenti di Didattica
Documenti di Professioni
Documenti di Cultura
Victor Dalton
Instagram: @victordalton
Facebook: Facebook.com/professorvictordalton
Youtube: youtube.com/victordalton
Linguagens de programao
Meio de comunicao entre mquinas e humanos
Linguagem de programao
Meio de comunicao entre mquinas e humanos
Lgica de programao
Lgica de Programao a tcnica de encadear pensamentos, com o intuito
de atingir determinado objetivo.
Lgica de programao
A lgica de uma determinada tarefa ou atividade centrada em um algoritmo.
Um algoritmo uma sequncia finita de passos que levam execuo de
determinada tarefa ou conjunto de tarefas.
Por exemplo, um algoritmo que calcule a mdia entre dois nmeros inteiros
dever:
1.
2.
3.
4.
Lgica de programao
Os algoritmos so definidos por cinco caractersticas. So elas:
Finitude: um algoritmo tem de terminar ao fim de um nmero finito de passos;
Clareza/definio: cada passo do algoritmo tem de ser definido com preciso,
sem ambiguidades;
Entrada: um algoritmo pode ter zero ou mais entradas;
Sadas: um algoritmo tem uma ou mais sadas;
Eficcia/efetividade: todas as operaes feitas por um algoritmo tm de ser
suficientemente bsicas.
Lgica de programao
Na computao, comum a escrita de algoritmos em uma linguagem comum,
que seja independente de linguagem de programao. Esta linguagem se chama
pseudocdigo, ou portugol.
ALGORITMO MEDIA_FINAL;
VAR NOTA1, NOTA2, NOTA3, NOTA4, MEDIA: INTEIRO;
NOME: CARACTERE [35]
INICIO
LER (NOME);
LER (NOTA1, NOTA2, NOTA3, NOTA4);
MEDIA:= (NOTA1 + NOTA2 + NOTA3 + NOTA4) / 4;
ESCREVER (NOME, MEDIA)
FIM.
ALGORITMO MEDIA_FINAL;
VAR NOTA1, NOTA2, NOTA3, NOTA4, MEDIA: INTEIRO;
NOME: CARACTERE [35]
INICIO
LER (NOME);
LER (NOTA1, NOTA2, NOTA3, NOTA4);
MEDIA:= (NOTA1 + NOTA2 + NOTA3 + NOTA4) / 4;
ESCREVER (NOME, MEDIA)
FIM.
Elementos de um algoritmo
Varivel
Espao da memria do computador que armazena um dado. No algoritmo, a varivel pode
ser manipulada pelas instrues, modificando e trabalhando seus valores.
Uma varivel recebe um nome (tambm chamado de identificador), que a diferencia das
demais, no algoritmo. Normalmente atribui-se um nome intuitivo varivel, para facilitar
o entendimento do prprio algoritmo.
ALGORITMO MEDIA_FINAL;
VAR NOTA1, NOTA2, NOTA3, NOTA4, MEDIA: INTEIRO;
NOME: CARACTERE [35]; (tipo de varivel, texto at 35 caracteres)
INICIO
LER (NOME);
LER (NOTA1, NOTA2, NOTA3, NOTA4);
MEDIA:= (NOTA1 + NOTA2 + NOTA3 + NOTA4) / 4;
ESCREVER (NOME, MEDIA)
FIM.
Elementos de um algoritmo
Constante
Constante, conforme o prprio nome diz, difere da varivel por no permitir
modificao em seus valores pelo algoritmo.
ALGORTIMO AREA_CIRCUNFERENCIA;
CONST PI = 3.1416;
VAR RAIO, AREA: REAL;
INICIO
LER (RAIO);
AREA:= PI * SQR(RAIO);
ESCREVER (AREA =, AREA)
FIM.
Elementos de um algoritmo
Declarao de variveis
Um algoritmo, via de regra, inicia-se pela declarao de variveis. Perceba no nosso
algoritmo exemplo, destacado em azul.
ALGORITMO MEDIA_FINAL;
VAR NOTA1, NOTA2, NOTA3, NOTA4, MEDIA: INTEIRO;
NOME: CARACTERE [35]
INICIO
LER (NOME);
LER (NOTA1, NOTA2, NOTA3, NOTA4);
MEDIA:= (NOTA1 + NOTA2 + NOTA3 + NOTA4) / 4;
ESCREVER (NOME, MEDIA)
FIM.
As constantes tambm so declaradas no incio do algoritmo, juntamente com as
variveis.
Elementos de um algoritmo
Instruo
A instruo o passo, ou etapa do algoritmo. Normalmente, a linha
de cdigo seguida de ponto-e-vrgula.
Elementos de um algoritmo
Conjunto de instrues
O conjunto de instrues a inteligncia do algoritmo, a sua razo de ser. Veja, em
destaque, no mesmo algoritmo:
ALGORITMO MEDIA_FINAL;
VAR NOTA1, NOTA2, NOTA3, NOTA4, MEDIA: INTEIRO;
NOME: CARACTERE [35]
INICIO
LER (NOME);
LER (NOTA1, NOTA2, NOTA3, NOTA4);
MEDIA:= (NOTA1 + NOTA2 + NOTA3 + NOTA4) / 4;
ESCREVER (NOME, MEDIA)
FIM.
Em pseudocdigo, costuma-se utilizar Inicio e Fim para delimitar o conjunto de
instrues.
Tipos de variveis
Os tipos primitivos mais comuns de variveis so:
INTEIRO nmero inteiro;
REAL nmero real;
CARACTERE (string) texto, que pode conter letras, smbolos e
nmeros;
LGICO (boolean) assumem apenas os valores verdadeiro ou falso.
Atribuio
Como voc l essa instruo?
MEDIA:= (NOTA1 + NOTA2 + NOTA3 + NOTA4) / 4;
Atribuio
varivel constante
varivel varivel
varivel expresso
varivel funo
Exemplo
A
A
A
A
45 (A recebe 45)
B (A recebe o valor de B)
B + C (A recebe o valor de B + C)
calculo(B,C) (A recebe o retorno da funo calculo)
Teste de Mesa
Realizar o teste de mesa acompanhar um algoritmo passo a passo,
mantendo uma tabela com os valores das variveis e registrar as
mudanas nestas variveis ao longo da execuo do mesmo.
ALGORITMO MEDIA_FINAL;
VAR NOTA1, NOTA2, NOTA3, NOTA4, MEDIA: INTEIRO;
NOME: CARACTERE [35]
INICIO
LER (NOME);
LER (NOTA1, NOTA2, NOTA3, NOTA4);
MEDIA:= (NOTA1 + NOTA2 + NOTA3 + NOTA4) / 4;
ESCREVER (NOME, MEDIA)
FIM.
Smbolo
*
/
+
-
Prioridade
1
1
2
2
Operador
>
<
=
>=
<=
<>
Significado
maior
menor
igual
maior ou igual
menor ou igual
diferente
Operao
Negao
Conjuno
Disjuno
Disjuno exclusiva
Operador
no
e
ou
xou (lido como ou exclusivo)
X
V
V
F
F
Y
V
F
V
F
XeY
X ou Y
no X
X xou Y
Estrutura sequencial
A estrutura sequencial a estrutura mais simples que um algoritmo pode
possuir. Nela, as instrues so executadas sequencialmente, passo a passo.
1.ALGORITMO MEDIA_FINAL;
2.VAR NOTA1, NOTA2, NOTA3, NOTA4, MEDIA: INTEIRO;
3.NOME : CARACTERE [35]
4.INICIO
5.LER (NOME);
6.LER (NOTA1, NOTA2, NOTA3, NOTA4);
7.MEDIA := (NOTA1 + NOTA2 + NOTA3 + NOTA4) / 4;
8.ESCREVER (NOME, MEDIA)
9.FIM.
Estruturas de seleo
As estruturas de seleo so aquelas em que, em algum passo, o
algoritmo verifica determinada condio para, ento seguir por algum
caminho.
Seleo simples (ou estrutura de desvio, ou estrutura condicional,
ou estrutura if-then)
Seleo composta (ou estrutura de desvio, ou estrutura
condicional, ou estrutura if-then-else)
Seleo aninhada
Seleo mltipla
Estruturas de repetio
Nas estruturas de repetio, possvel colocar um trecho de cdigo em
loop, ou lao de repetio, executando at que uma condio seja
atingida, ou enquanto uma condio permanecer vlida.
Repetio com verificao antecipada
Repetio com verificao ao final
Repetio com varivel de controle
atribuir 50 a I
atribuir 0 a TOTAL
atribuir 0 a K
enquanto K < I faca
incio
somar 10 a K;
atribuir TOTAL+K a TOTAL
imprimir(K);
fim;
fim-enquanto;
imprimir(TOTAL);
atribuir 50 a I
atribuir 0 a TOTAL
atribuir 0 a K
enquanto K < I faca
incio
somar 10 a K;
atribuir TOTAL+K a TOTAL
imprimir(K);
fim;
fim-enquanto;
imprimir(TOTAL);
Muito Obrigado!
Victor Dalton
Instagram: @victordalton
Facebook: Facebook.com/professorvictordalton
Youtube: youtube.com/victordalton