The New Stuff

C/C++: Algoritmo de Fatoração de Fermat (FFA) em C


FFA: Fermat Factoring Algorithm (Algoritmo de Fatoração de Fermat)

Procedimento simples de fatoração inventado por Pierre de Fermat:

Todo numero pode ser escrito como diferença de dois números elevados ao quadrado:

n = a² – b², ou n = a*a – b*b;

Esta expressão pode ser escrita como n = (a+b) * (a-b), ou n = (a+b) (a-b), onde a soma e a subtração dos valores “a” e “b” são dois fatores do número em questão.

Se n é primo, então a-b = 1 e a+b=n;

Para números com diversos fatores e divisores existem diversos “a” e “b” que satisfazem a expressão.

Este algoritmo testa em progressão diversos valores “b” em “i + j*j”, ou i + j², com i=n no primeiro passo.

Se i + j*j for um quadrado perfeito, entao calcula-se com base nisto os correspondentes a e b da expressão anterior, tendo-se então encontrado um fator.

Fator este que não é necessariamente um número primo.

Obs[1]: Possível otimizá-lo. Este fica a exemplo de contexto.

Obs[2]: Compilar com a seguinte linha de comando:
(bem lembrado pela moderação) :-)

gcc fermat001.c -o fermat001 -lm

-lm faz ligação com a libm, biblioteca de funções matemáticas do C.


Viva o Linux

Recently Published

article image
»

Linux: Órfãos vs Zumbis

Enviado por Eri Bastos (bastos·eriΘgmail·com): “Definir e ...

article image
»

Varnish para aumentar o desempenho do seu site

Enviado por Ricardo Ferreira Costa ...

article image
»

Instale uma interface gráfica para o youtube-dl com Youtube-DLG

Enviado por Edivaldo Brito (edivaldobezerraΘgmail·com): “Se você ...

article image
»

Wine 1.7.43 traz melhorias na arquitetura ARM64

Enviado por Pedro Jefferson ...

article image
»

Tutorial Nessus Home Parte 2 (Final)

Enviado por Pedro Jefferson ...

article image
»

VENOM: Bug na virtualização de drives de disquete coloca em risco servidores e máquinas virtuais

Quem usa o QEMU ou outros sistemas de virtualização que usam ...

article image
»

Usando o Hangouts-Chat via terminal

Enviado por Pedro Jefferson ...

article image
»

Sorteio do livro PHP Moderno no blog buteco opensource

Enviado por Pedro Jefferson ...

article image
»

CONSOLINE – Software Livre e conhecimento. Não percam o próximo!

Enviado por Alessandro de Oliveira Faria (A.K.A. CABELO) ...