Algoritmo

O algoritmo é um conjunto de instruções escritas por um programador com intuito de solucionar um problema ou obter um resultado previsto.

Categoria de Tecnologia

Postado em 21 agosto 2022

Atualizado em 21 agosto 2022

Palavras-chave: algoritmo,programacao,programming,solution,problem,big,ozao,tecnologia

Visualizações: 2823



A ciência da computação tem crescido consideravelmente nos últimos anos, porém qualquer dispositivo eletrônico ainda é totalmente dependente de humanos.

Aparelhos como televisões, microondas e máquinas de lavar roupa são exemplos de objetos com um microcomputador embutido, programado para funcionar corretamente.

Funcionar corretamente significa operar da forma como o consumidor ordenou. Por exemplo, ao apertar o botão de ligar da televisão, ela deve ligar, assim como a máquina de lavar roupa deve começar a lavar quando apertamos o botão de início.

Além dessas operações básicas, essas máquinas também estão programadas para funcionar de muitas outras formas, como em caso de excessões, causadas por ordens inesperadas do consumidor.

Todos esses cenários devem ser analisados com cuidado, pois no pior dos casos, podem até trazer riscos ao próprio consumidor.

Todas essas instruções são escritas por um programador, através de um algoritmo.

O que é um algoritmo?

Algoritmo é um conjunto de instruções com o intuito de solucionar um problema ou obter um resultado já esperado. Para esses resultados poderem ser obtidos, o algoritmo precisa ser um processo finito.

Para um algoritmo ter sucesso, as instruções devem ser executadas na mesma ordem como foram escritas de forma precisa e sem pular etapas.

Uma vez que etapas são negligenciadas, o algoritmo perde a sua eficiência trazendo resultados inesperados.

Algoritmo em outras áreas

A expressão “algoritmo” não se limita apenas a ciência da computação, podendo ser usada em outros contextos.

Por exemplo, quando perguntamos para uma pessoa na rua como chegar em um determinado destino, essa pessoa irá oferecer uma série de instruções para resolvermos o problema de como chegar nesse local.

Dependendo da pessoa, essas instruções podem variar, podendo ter sua eficiência afetada negativamente ou positivamente.

O que é o algoritmo na ciência da computação?

O algoritmo na ciência da computação funciona da mesma forma como explicado acima, porém a grande diferença é que as instruções escritas no algoritmo vão ser operadas pela máquina.

algoritmo flowchart

Para um algoritmo poder ser implementado é necessário o uso de uma linguagem de programação.

Atualmente, existem linguagens com vantagens específicas para desenvolvimento web, aplicativos e jogos.

A importância do algoritmo na ciência de computação

Diferente de um humano, a máquina possui muito mais velocidade de execução, podendo executar milhões de instruções por segundo.

Mesmo possuindo essa velocidade de execução, a máquina pode ter seu desempenho afetado devido a um algoritmo mal-escrito.

O avanço da tecnologia permitiu que uma grande quantidade de dados possam ser executados pelo CPU, porém algoritmos ineficientes podem trazer falhas ao sistema, que pode deixar de responder em um cenário pessimista.

Como medir a eficiência de um algoritmo?

As linguagens de programação trazem diversas funcionalidades que facilitam o desenvolvimento de software.

Processos de repetição (loop), condições (if) e estrutura de dados (array) são exemplos desse tipo de funcionalidade.

Porém, práticas como força bruta na programação não é algo recomendável em cenários que utilizam uma grande quantidade de dados de entrada.

Um modo de medir a eficiência de um algoritmo pode ser efetuado através do método da notação do O grande.

Analisando o algoritmo no pior dos cenários é essencial para avaliar se o software atende os requerimentos mínimos de operação.

Conclusão

O algoritmo na ciência da computação é um conjunto de instruções escritas por um programador com intuito de solucionar um problema ou obter um resultado previsto.

Um algoritmo pode ter seu desempenho afetado, dependendo das técnicas utilizadas pelo desenvolvedor.

Uma boa forma de avaliar o tempo de processamento de um algoritmo é através do método big-O.

Projetos práticos

Criando o esqueleto de um jogo de tiro 2D visto de cima usando P5.js

Usando lógicas matemáticas como trigonometria para criar e calcular o esqueleto de um jogo de tiro 2D em javascript

Caixa eletrônico usando arquitetura limpa

Usando JavaFX e arquitetura limpa para criar um aplicativo de caixa eletrônico extremamente simples.

Criando artes de texto usando imagens

Convertendo imagens para ascii art usando o valor da intensidade das cores cinzentas.

Criando um jogo de pacman usando javascript e pixi.js (parte 1)

Desenvolvimento dos conceitos mais básicos do clássico pacman, como: mapa, animação, deslocamento e detector de colisões.

Criando um jogo de guerra nas estrelas em javascript usando a biblioteca p5.js

Jogo simples de guerra espacial desenvolvido em javascript. Esse jogo usa cálculos de física para simular efeitos de atrito e inércia.

Veja também

Nunca se sabe quando tem alguém nos espionando no nosso computador

Um computador conectado à internet está exposto a diversos perigos. O spyware é um deles e é esse malware responsável por roubar contas de redes sociais.

Os três pilares de segurança da informação são o requerimento mínimo para um serviço seguro

A quantidade de programadores só tende a aumentar com o tempo. Porém, muitos programadores ainda não conhecem os três pilares de segurança da informação.

Princípio aberto fechado - Open-Closed Principle

O código deve estar aberto para extensões e fechado para modificações. Podemos mudar o comportamento de uma classe adicionando mais código.

Princípio de substituição de Liskov - Liskov Substitution Principle

Esse princípio diz que uma classe derivada deve ser substituível pela sua classe base sem apresentar comportamentos inesperados.

POJO e Java Bean

Expressões utilizadas na linguagem Java para descrever classes simples que contém atributos, getters e setters de um objeto.

Linguagem de programação

A linguagem de programação é um conjunto de instruções que possuem um padrão de escritas, sendo um intermediário entre o programador humano e a máquina.