Função Fatorial Recursiva em Ada 95

Publicado por Perfil removido (última atualização em 26/01/2016)

[ Hits: 2.325 ]

Download fatorial-0001.adb




Este é um exemplo simples de uma função fatorial recursiva em Ada 95. Cheguei a ler um texto onde era citado que Ada é uma linguagem da família Pascal. Até parecem um pouco.

Para a compilação pode ser usado o gnatmake. Ele vem junto com o pacote GNAT nas principais distribuições Linux. Uso:

$ gnatmake fatorial-0001.adb

Caso seja feita uma tentativa de compilação com o gnat, resultará no seguinte, conforme abaixo:

$ gnat fatorial-0001.adb
gcc-4.9 -c fatorial-0001.adb
fatorial-0001.adb:4:11: warning: file name does not match unit name, should be "mostra.adb"

Esta crítica sugere que o nome do arquivo deve ter o mesmo nome do programa declarado na primeira declaração Procedure. Mesmo sem fazer isto, tudo parece funcionar normalmente.

Continuando:

Este é um exemplo simples, sem aprofundamento. O objetivo é ilustrar uma pequena parte da sintaxe de um programa em ADA. No caso um programa com função recursiva.

Posso dizer que até onde vi, Ada parece uma espécie de mistura de Pascal com Java.

Coisas como System.out.println() são semelhantes a Ada.Text_IO.Get() ou Ada.Text_IO.Put(). As semelhanças com Pascal são maiores e aparecem mais em outras instruções de declaração de tipos e registros, que não constam no exemplo. Uma semelhança relevante é que não é case sensitive.

A diferença é que colocando as bibliotecas com With e Use na primeira linha estes comandos podem ser abreviados para Get() e Put(). Get não foi usado nesta oportunidade.

Uma coisa que chama a atenção é o fato de que todo programa deve estar declarado como "Procedure Nome_do_Programa" (semelhante ao "Program Nome_do_Programa" do Pascal) e ainda deve ser seguido da partícula is. Os comandos do programa são implementados entre um Begin e um End. Este último End do programa não termina com o ponto final igual ao Pascal, mas sim com "End Nome_do_Programa", seguido de um ponto-e-vírgula.

A implementação da função Fatorial se dá antes do Begin de início do código. Ao invés de se igualar o retorno da função ao nome da mesma, retorna-se o resultado com o comando Return (semelhante ao C).

A estrutura de decisão IF é semelhante ao Pascal, com IF, THEN, ELSE, mas neste caso completa-se com END IF. Neste exemplo não aparece o que seria semelhante à estrutura CASE, ficando para uma próxima.

Ao invés de se usar um WriteLn para a mudança de linha, usa-se simplesmente o comando New_Line. O comando Put é usado semelhante ao comando Write, sem mudança de linha.

A linguagem Ada é poderosa, tendo inúmeros usos estratégicos na indústria, como programação concorrente e orientada a objetos. Não é o objetivo de abordá-los neste micro-artigo.

  



Esconder código-fonte

With Ada.Text_IO, Ada.Integer_Text_IO;
Use Ada.Text_IO, Ada.Integer_Text_IO;

Procedure Mostra is

   Function Fatorial (n1:Integer) return Integer is
   Begin
      If n1 = 0 Then
         Return 1;
      Else
         Return (n1 * Fatorial (n1 - 1));
      End If;
   End Fatorial;

Begin

   Put("O fatorial de 8 eh ");
   Put(Fatorial(8),2);
   Put(".");
   New_Line;

End Mostra;

Scripts recomendados

Calculadora básica no Lazarus

Calculadora utilizando until e case

Existência de triângulo, em Pascal

calculo de porcentagem em vetores

Rompecompiladores Ackerman


  

Comentários
[1] Comentário enviado por fabio em 26/01/2016 - 10:54h

Interessante. Nunca havia ouvido falar dessa linguagem.

[2] Comentário enviado por Arthur_Hoch em 05/02/2016 - 13:53h

Por que aprender ADA?

Eu não gosto de pascal nem de delphi. :v

[3] Comentário enviado por removido em 05/02/2016 - 19:48h

O que chama a atenção é quem usa a linguagem e para o quê.

----------------------------------------------------------------------------------------------------------------
http://24.media.tumblr.com/tumblr_m62bwpSi291qdlh1io1_250.gif

# apt-get purge systemd

Encryption works. Properly implemented strong crypto systems are one of the few things that you can rely on. Unfortunately, endpoint security is so terrifically weak that NSA can frequently find ways around it. — Edward Snowden


Contribuir com comentário




Patrocínio

Site hospedado pelo provedor RedeHost.
Linux banner

Destaques

Artigos

Dicas

Tópicos

Top 10 do mês

Scripts