Lista de números aleatórios não-repetidos de um intervalo em Perl
Publicado por Perfil removido (última atualização em 16/04/2012)
[ Hits: 5.945 ]
Este script gera uma lista unidimensional tamanho N, preenchendo esta completamente com números aleatórios no intervalo de 1 até N sem repetições.
Gera-se um número aleatório, este é verificado se foi inserido anteriormente. Se caso não, ele o insere e repete o procedimento, senão ele gera outro valor e procura novamente se repetiu. Até que a lista esteja por completo cheia com um valor de cada.
Repetições podem ser visualmente identificadas através de:
$ ./alea001,pl | sort -n --key=2
Escolheu-se o valor 52 para teste por ser este o número de cartas de um baralho-padrão.
A verificação de repetições tornar-se á exaustiva caso não seja automatizada.
Por enquanto não constam falhas, sendo que na versão em C já constei por algo. Logo podem haver.
#!/usr/bin/perl
use strict;
use warnings;
# Para testar se não há números repetidos, usar por exemplo:
# ./alea001.pl | sort -n --key=2
BEGIN { srand() if $] < 5.004 }
my $VALOR = 52;
my ($i, $j, $k);
my @vec = ();
my $n = $VALOR;
$i = 0;
while ($i<$n) { $vec[$i++] = -1; }
($i, $j) = (0, 0);
while ($i<$n) {
$j = 1 + int rand($n);
$k = 0;
while ($k<=$i && $vec[$k++]!=$j) {}
$vec[$i++] = $j if ($k==$i+1);
}
$i = 0;
while ($i<$n) { print "$i\t$vec[$i++]\n"; }
#print "\n";
Renomeando arquivos de forma padronizada
Cálculo de área de uma figura geométrica
Nenhum comentário foi encontrado.
Maquina modesta - a vez dos navegadores ferrarem o usuario
Fscrypt: protegendo arquivos do seu usuário sem a lentidão padrão de criptograr o disco
Faça suas próprias atualizações de pacotes/programas no Void Linux e torne-se um Contribuidor
Resolvendo o bloqueio do Módulo Warsaw no Arch Linux (Porta 30900)
Replicação SYSVOL no Samba 4 com Syncthing
Samba 4 com Replicação e LDAP Seguro (LDAPS/TLS)
Configurando o Cairo Dock individualmente em ambientes diferentes na mesma maquina
Calculadoras online gratuitas para o dia a dia do usuário Linux
Metafísica e espiritualidade funciona de verdade! Comprovação pessoal (13)
Warsaw não é reconhecido no Google Chrome 147.0.7727.55 (6)
Governo da França vai trocar Windows por Linux (8)









