Índice (Logaritmo Discreto) em Perl
Publicado por Perfil removido (última atualização em 26/04/2013)
[ Hits: 3.717 ]
O problema do índice se resume a:
"Dado dois inteiros N e B, qual o menor expoente I tal que B elevado à I e dividido por N tenha resto igual a 1?"
Se ao invés deste resto 1 for usado um valor R, com o valor de R estando entre 0 e N-1 tem-se então o problema do logaritmo discreto.
Para B=2 e N=31, I vale 5. => 2,4,8,16,32 => 32/31 resto = 1
Para B=4 e N=60, não existe resposta válida. => 4, 16, 64 => 64/60 resto 4 e permanece num ciclo fechado.
Ou 64%60 = 4, que é como se escreve em algumas linguagens.
Este programa calcula índice por brute-force.
#!/usr/bin/perl
use strict;
use warnings;
sub indice {
my ($base, $mod) = (shift, shift);
my ($index, $acum) = (1, $base % $mod);
$base %= $mod;
do {
$acum *= $base;
$acum %= $mod;
$index++;
} until ($acum == $base || $acum == 1);
($acum==1) ? return $index : return -1;
}
my $B = 5;
my $N = 64;
my $I = indice($B, $N);
print "$I\n";
Verificação se utilizador existe ou não
Remover lista de pacotes do Portage
Calculadora com Perl com menos de 10 linhas de código
Nenhum comentário foi encontrado.
Cirurgia para acelerar o openSUSE em HD externo via USB
Void Server como Domain Control
Modo Simples de Baixar e Usar o bash-completion
Monitorando o Preço do Bitcoin ou sua Cripto Favorita em Tempo Real com um Widget Flutuante
[Resolvido] VirtualBox can't enable the AMD-V extension
Como verificar a saúde dos discos no Linux
Como instalar , particionar, formatar e montar um HD adicional no Linux?
Como automatizar sua instalação do Ubuntu para desenvolvimento de software.
Fiz uma pergunta no fórum mas não consigo localizar (14)
Quais os códigos mais dificeis que vcs sabem fazer? (3)
Upscaling com imagem cortada no monitor secundário ao usar iGPU Multi ... (1)
Não consigo instalar distro antiga no virtualbox nem direto no hd (7)
Servidor Ubuntu 24.04 HD 500 não tenho espaço na \home\adminis... [RES... (8)









