Você está na página 1de 8

TÉCNICAS DE DESENVOLVIMENTO DE ALGORITMOS

INTRODUÇÃO À LÓGICA DE PROGRAMAÇÃO

Objetivos
● Estabelecer os conceitos fundamentais da lógica;
● aplicação da lógica no cotidiano;
● definição de algoritmos;
● estabelecer a relação entre lógica e algoritmos: a lógica de programação;
● exemplificar a aplicação dos algoritmos em situações cotidianas;
● comparação das principais formas de apresentação.

Noções de lógica
Comumente associado no dia a dia a coerência e racionalidade. Com muita frequência tem sua
ligação associada unicamente à matemática, desassociada com as demais ciências. Como filosofia, procura
saber o porquê de determinados pensamentos serem de um jeito e não de outro.
Pode-se ainda entender que a lógica tem em vista a ordem da razão, já que se pode pensar de forma
desordenada. A lógica então ensina como colocar ordem no pensamento.
A lógica tem como objetivo o estudo de técnicas de formalização, dedução e análise que permite
validar argumentos.

Lógica na programação
Significa o uso correto das leis do pensamento, da ordem da razão e de processos de raciocínio e
simbolização formais na programação de computadores, tendo como objetivo trazer racionalidade e o
desenvolvimento de técnicas que cooperem para a produção de soluções logicamente válidas e coerentes
que resolvam com qualidade os problemas que se deseja programar.

Algoritmo
Pode ser definido como uma sequência de passos que visam atingir um objetivo definido. Apesar de
parecerem pouco conhecidos, são comuns no nosso dia a dia, como o passo a passo da receita de um bolo.
Devem ser especificados com ações claras e precisas, que a partir do estado inicial e por um tempo
finito, produz-se um resultado final previsível e bem definido. Sempre que esse percurso for feito, deverá
trazer os mesmos resultados, fixando-se assim um padrão de comportamento.
O algoritmo tem por objetivo representar mais fielmente o raciocínio de lógica da programação,
abstraindo uma série de detalhes computacionais que poderão ser usados em outro momento. Uma vez
encontrada a solução algorítmica, pode ser traduzida para qualquer linguagem de programação, agregando
funcionalidades nos diversos ambientes, esse processo denomina-se codificação.

Representação algorítmica
Algoritmo segue uma linha de raciocínio descrito de forma textual (português coloquial) ou gráfica. As
formas gráficas são mais fiéis ao raciocínio original, dispensando um grande número de palavras por
convenções de desenhos.
Apesar de ambas as formas terem suas vantagens e desvantagens, permitem um grande nível de
clareza quanto ao fluxo de execução, no entanto são menos fáceis de entender em comparação com a forma
textual, uma vez que se faz necessário conhecer as convenções gráficas de cada uma das técnicas, que
apesar de simples não são naturais, já que as nossas expressões se dão por meio de palavras.
Outra desvantagem é ser mais trabalhoso, podendo ser necessários o uso de réguas e moldes. A
problemática é maior quando se precisa corrigir algum desenho. Tais fatores desencorajam o uso das
representações gráficas e às vezes, levam a erros na construção algorítmica.
Justificando-se assim o uso dos textos que apesar de serem menos puros, são mais fáceis e naturais
de usar.
Tipos de algoritmos
● Descrição narrativa;
● fluxograma convencional;
● Diagrama de Chapin;
● pseudocódigo (linguagem estruturada ou Portugol).

TÓPICOS PRELIMINARES

Objetivos
● Apresentação dos tipos básicos de dados;
● definição e utilização de constantes e variáveis;
● definição do processo de atribuição;
● importância e aplicação dos comandos de entrada e saída;
● conceituação de blocos lógicos.

Tipos primitivos
Informação é o que torna necessário a existência dos computadores, pois eles são capazes de
manipular e armazenar um grande volume de dados com alta performance. A diferença entre dado e
informação é sutil, onde por exemplo: a data 21 de setembro é apresentada como um dado, ao dizer que é o
Dia da Árvore, estamos agregando valor ao dado, apresentando assim a informação.
Existem quatro tipos primitivos de dados usados na construção algorítmica.
Inteiro: toda e qualquer informação numérica que pertença ao conjunto dos números inteiros relativos:
negativo, nulo ou positivo. Exemplos: a) Ele tem 15 irmãos. b) A escada possui 8 degraus. c) Meu vizinho
comprou 2 carros novos.
Real: toda e qualquer informação numérica que pertença ao conjunto dos números reais: negativo,
nulo ou positivo. Exemplos: a) Ela tem 1,73 metro de altura. b) Meu saldo bancário é de $215,20. c) No
momento estou pesando 82,5 kg.
Carácter: toda e qualquer informação composta de um conjunto caracteres alfanuméricos: numéricos
(0…9), alfabéticos (A…Z, a…z) e especiais (#, ?, !, @). Exemplos: a) Constava na prova “Use somente
caneta!”, b) O parque municipal estava repleto de placas “Não pise na grama”. c) O nome do vencedor é
Felisberto Laranjeira.
Lógico: toda e qualquer informação que pode assumir apenas duas situações (biestável). Exemplos:
a) A porta pode estar aberta ou fechada. b) A lâmpada pode estar acesa ou apagada.

Constantes
Aquele dado que não sofre nenhuma variação no decorrer do tempo, desde o início até o fim da
execução do algoritmo, sendo constante em diferentes execuções temporais.
Para diferenciar os dados constantes do tipo caracter dos outros tipos usaremos aspas duplas (“ “)
para delimitá-los. Convencionamos que as informações do tipo lógico poderão assumir os seguintes valores
constantes: verdade (V) ou falsidade (F).
Exemplo: 5, “Não fume”, 2527, -0,58, V

Variável
Um dado é classificado como variável quando há a possibilidade de ser alterado em algum momento,
ou seja, durante a execução do algoritmo em que é utilizado, o valor do dado sofre alteração, ou o dado é
dependente da execução em um certo momento ou circunstância.
Exemplo: A cotação do dólar, o peso de uma pessoa, o índice da inflação.

Expressões aritméticas
São assim denominados cujos operadores são aritméticos e os operandos são constantes ou variáveis
do tipo numérico (inteiro ou real).
Operadores aritméticos
Chamados de operadores aritméticos, o conjunto de símbolos que representa as operações básicas
da matemática.

Para representar as operações de radiciação e potenciação, usaremos as palavras-chave rad e pot.

Outras operações matemáticas não convencionais, porém úteis na construção de algoritmos, são o
resto da divisão e o quociente da divisão inteira.

Prioridades
Na resolução das expressões aritméticas, existe uma hierarquia entre si. 1) Parênteses mais internos,
2) pot rad, 3) * / div mod, 4) + -
Em caso de empate (operadores de mesma prioridade), deve-se resolver da esquerda para a direita,
conforme a sequência existente na expressão aritmética. Para alterar a prioridade da tabela, utilizamos
parênteses mais internos. Exemplos:
a) 5 + 9 + 7 + 8 / 4
5+9+7+2
23
b) 1 - 4 * 3 / 6 - pot (3,2)
1-4*3/6-9
1 - 12 / 6 - 9
1-2-9
-10
c) pot (5,2) - 4 / 2 + rad (1 + 3 * 5) / 2
pot (5,2) - 4 / 2 + rad (1 + 15) / 2
pot (5,2) - 4/ 2 + rad (16) / 2
25 - 4 / 2 + 4 / 2
25 - 2 + 2
21
Expressões lógicas
São denominados cujos operadores são lógicos ou relacionais e os operandos são relações ou
variáveis ou constantes do tipo lógico.

Operadores relacionais
Utilizado para realizar comparações entre dois valores de mesmo tipo primitivo. Esses valores são
representados por constantes, variáveis ou expressões aritméticas. São comuns para construção de
equações.

O resultado obtido de uma relação é sempre um valor lógico. Exemplo: analisando a relação numérica
A + B = C, o resultado será verdade ou falsidade a medida que o valor da expressão aritmética A + B seja
igual ou diferente do conteúdo da variável C, respectivamente.

Exemplos:
a) 2 * 4 = 24 / 3
8=8
V
b) 15 mod 4 < 19 mod 6
3<1
F
c) 3 * 5 div 4 <= pot (3,2) / 0,5
15 div 4 <= 9 / 0,5
3 <= 18
Operadores lógicos
São utilizados três operadores lógicos para a formação de novas proposições lógicas compostas a
partir de outras proposições simples.

Tabelas-verdade
Conjunto de todas as possibilidades combinatórias entre os valores de diversas variáveis lógicas, as
quais se encontram em apenas duas situações (V ou F), e um conjunto de operadores lógicos.

Exemplos:
a) Se chover e relampejar, eu fico em casa.
Quando eu fico em casa?
Observamos na tabela-verdade do conectivo usado anteriormente e que a preposição só será
verificada (ou seja, eu fico em casa) quando os termos chover e relampejar forem simultaneamente verdade.
b) Se chover ou relampejar eu fico em casa.
Quando eu fico em casa?
Percebemos que, com o operando lógico ou, as possibilidades de “eu fico em casa” se tornam
maiores, pois, pela tabela-verdade, a proposição será verdadeira em três situações: somente chovendo,
somente relampejando, chovendo e relampejando.
c) 2 < 5 e 15 / 3 = 5
Ve5=5
VeV
V
d) 2 < 5 ou 15 / 3 = 5
V ou V
V
e) F ou 20 div (18 / 3) <> (21 / 3) div 2
F ou 20 div 6 <> 7 div 2
F ou 3 <> 3
F ou F
F
f) não V ou pot (3,2) / 3 < 15 - 35 mod 7
não V ou 9 / 3 < 15 - 0
não V ou 3 < 15
não V ou V
F ou V
V

Prioridades
Entre operadores lógicos:

Exemplos:
a) não (5 <> 10 / 2) ou V e 2 - 5 > 5 - 2 ou V)
não (5 <> 5) ou V e 3 > 3 ou V)
não (F ou V e F ou V)
não (F ou F ou V)
não (F ou V)
não (V)
F
b) pot (2,4) <> 4 + 2 ou 2 + 3 * 5 / 3 mod 5 < 0
16 <> 6 ou 2 + 15 / 3 mod 5 < 0
16 <> 6 ou 2 + 5 mod 5 < 0
16 <> 6 ou 2 + 0 < 0
16 <> 6 ou 2 < 0
V ou F
V

Comando de atribuição
Permite fornecer um valor a uma variável, em que tipo do dado deve ser compatível com o tipo da
variável, isto é, só podemos atribuir um valor lógico a uma variável capaz de comportá-lo, ou seja, uma
variável declarada como sendo do tipo lógico. O comando de atribuição possui a seguinte sintaxe:
Exemplos:
a) Lógico: A, B;
Inteiro: X;
A ← B;
X ← 8 + 13 div 5;
B ← 5 = 3;
X ← 2;

Comandos de entrada e saída


Os algoritmos necessitam ser alimentados com dados provenientes do meio externo para que sejam
efetuadas as operações e cálculos que são necessários a fim de alcançar o resultado desejado.

Entrada de dados
Para que ocorra a entrada de dados, necessita-se a realização de um comando, cuja finalidade é
atribuir o dado a ser fornecido a variável identificada.

Saída de dados
Para que o algoritmo possa mostrar os dados que calculou, surge o comando de saída, cuja finalidade
é exibir o conteúdo da variável identificada.

Blocos
Pode ser definido como um conjunto de ações com uma função definida, podendo o algoritmo ser visto
como um. Também serve para definir os limites nos quais as variáveis declaradas em seu interior são
conhecidas.

ESTRUTURAS DE CONTROLE

Objetivos
● Apresentar o conceito de estrutura sequencial de fluxo de execução;
● ilustração da construção de algoritmos através das etapas lógicas;
● explicar a aplicabilidade das estruturas de seleção, suas variantes, combinações e equivalências;
● apresentar estruturas de repetição, suas particularidades, aplicações e equivalências.

Utiliza-se os conceitos de blocos lógicos na criação dos algoritmos, entrada e saída de dados,
variáveis, constantes, atribuições, expressões lógicas, relacionais e aritméticas, assim como os comandos
relacionados para que representem o conjunto de ações.
O fluxo de execução do algoritmo nada mais é que a perfeita relação lógica intrínseca desse conjunto
de ações executáveis. As estruturas básicas possibilitam a criação de algoritmos na resolução de problemas,
essas estruturas básicas do controle de fluxo de execução são: sequenciação, seleção, repetição e
combinação dessas.
Estrutura sequencial
A estrutura sequencial de um algoritmo corresponde a execução de ações primitivas de forma linear
de cima para baixo e da esquerda para a direita, sendo da forma como foram escritas.
As ações serão seguidas por ponto e vírgula (;) que separa uma ação da outra e auxilia na
organização sequencial das ações, que logo após o (;) deverá ser executado na próxima sequência.

Estruturas de seleção
Uma estrutura de seleção permite a escolha de um grupo de ações (bloco) a ser executado quando
determinadas as condições, representadas por expressões lógicas ou relacionais, são ou não satisfeitas.

Seleção simples
Quando precisamos testar uma certa seleção antes de executar uma ação, usamos a seleção
simples, que segue o seguinte modelo:

se (condição)
então
C; // comando único (ação primitiva)
fimse;
<condição> é uma expressão lógica, que quando inspecionada, pode gerar um resultado falso ou
verdadeiro.
Se <condição> for verdadeira, a ação primitiva sob cláusula então (C) será executada; caso contrário,
encerra-se a seleção fimse, neste caso sem executar nenhum comando

Você também pode gostar