<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="Generator" content="Microsoft Exchange Server">
<!-- converted from text --><style><!-- .EmailQuote { margin-left: 1pt; padding-left: 4pt; border-left: #800000 2px solid; } --></style>
</head>
<body>
<div class="PlainText">Buss,<br>
Obrigado por analisar o código. <br>
Realmente eu fiz apenas alguns teste mas nao o suficiente para perceber esses bugs que me falou.<br>
Essa heurística foi apenas experimental.<br>
E ainda pode ser otimizada. <br>
Nao sou muito habilidoso quando se trata de achar esses tipos de erros.<br>
Por exemplo, se na rotina de geração de palíndromo eu verificasse se o palíndromo gerado e par já ganharia no desempenho mas nao resolveria os problemas que citou.<br>
Vou ver o que posso fazer para resolver esses bugs.<br>
 Obrigado pela análise.<br>
<br>
<br>
Bruno Buss <bruno.buss@gmail.com> escreveu:<br>
<br>
</div>
<div>
<div dir="ltr">Olá Aureliano,
<div><br>
</div>
<div>Muito bom seu esforço... mas eu acho que você deveria elaborar e rodar alguns testes unitários para o seu código. :-)</div>
<div><br>
</div>
<div><br>
</div>
<div>Por exemplo, o seu código anterior (com as subs _par e _impar), imprimia "101" se o time() fosse "102". A resposta correta seria "131". A sua "heurística geradora de palindromos" andou para trás nesse caso... me parece um erro de design do algoritmo.</div>
<div><br>
</div>
<div><br>
</div>
<div>Essa sua nova versão:</div>
<div>* Imprime "13" se o time() for "13"... e 13 nem é palindromo! O resultado correto nesse caso é "101". Mas isso é só um erro no seu loop principal, que se for primo direto no começo ele nem verifica se é palindromo mas já imprime direto.</div>
<div><br>
</div>
<div>* Imprime "1003001" se o time() for 96... o que me parece meio longe do resultado esperado, "101". Nesse caso, emho, o problema é a sua "heurística geradora de palindromos".</div>
<div><br>
</div>
<div><br>
</div>
<div><br>
</div>
<div>Ou seja, a eficiência do algoritmo é muito importante... mas sua corretude deve vir antes. (A menos é claro que estejamos falando de algoritmos aproximativos ou heurísticas para problemas intratáveis :-)</div>
<div><br>
</div>
<div>Nesse caso em específico, parece que essa sua função geradora de palindromos é de fato uma heurística para dar bumps na sequência e economizar verificações... mas como observado você corre o risco de pular algo que não deveria.</div>
<div><br>
</div>
<div>Só como dúvida, essa sua heurística é fundamentada em algum resultado matemático de fato ou apenas experimental?</div>
<div><br>
</div>
<div><br>
</div>
<div>[ ]'s</div>
<div>Buss</div>
<div><br>
</div>
<div class="x_gmail_extra"><br>
<br>
<div class="x_gmail_quote">2014-04-27 3:06 GMT-03:00 Aureliano Guedes <span dir="ltr">
<<a href="mailto:guedes_1000@hotmail.com" target="_blank">guedes_1000@hotmail.com</a>></span>:<br>
<blockquote class="x_gmail_quote" style="margin:0 0 0 .8ex; border-left:1px #ccc solid; padding-left:1ex">
<div>
<div dir="ltr">Esquece a ultima versão.
<div>Divisão é pesado para o processador. </div>
<div><br>
</div>
<div>Fiz uma versão menor com menos divisões que parece ter uma melhor performance.</div>
<div><br>
</div>
<div><a href="http://pastebin.com/jrjEv3eh" target="_blank">http://pastebin.com/jrjEv3eh</a><br>
<div class="x_hm x_HOEnZb"><br>
</div>
<div>
<div class="x_hm x_HOEnZb">
<hr>
From: <a href="mailto:guedes_1000@hotmail.com" target="_blank">guedes_1000@hotmail.com</a><br>
To: <a href="mailto:rio-pm@pm.org" target="_blank">rio-pm@pm.org</a><br>
Date: Sun, 27 Apr 2014 02:44:57 +0000</div>
<div>
<div class="x_h5"><br>
Subject: Re: [Rio-pm] [GOLF] Descanso de Pascoa: Maior palindromo<br>
<br>
<div dir="ltr">Então tenho essa versão que executou em 1s.
<div><br>
</div>
<div><a href="http://pastebin.com/DLdPwAkp" target="_blank">http://pastebin.com/DLdPwAkp</a><br>
<br>
<div>
<hr>
From: <a href="mailto:blabos@gmail.com" target="_blank">blabos@gmail.com</a><br>
Date: Sat, 26 Apr 2014 18:39:15 -0300<br>
To: <a href="mailto:rio-pm@pm.org" target="_blank">rio-pm@pm.org</a><br>
Subject: Re: [Rio-pm] [GOLF] Descanso de Pascoa: Maior palindromo<br>
<br>
<div dir="ltr">Vamos dar um desconto por causa do "primo".</div>
<div><br>
<br>
<div>2014-04-25 23:26 GMT-03:00 Junior Moraes <span dir="ltr"><<a href="mailto:juniiior182@gmail.com" target="_blank">juniiior182@gmail.com</a>></span>:<br>
<blockquote style="border-left:1px #ccc solid; padding-left:1ex">
<div dir="ltr">Hi.
<div><br>
</div>
<div>Se for válido usar módulos externos, dá pra implementar com o Math::Prime::XS para ficar mais performático. :-)</div>
<div><br>
</div>
<div>[]'s</div>
</div>
<div><br>
<br>
<div>Em 25 de abril de 2014 23:21, Aureliano Guedes <span dir="ltr"><<a href="mailto:guedes_1000@hotmail.com" target="_blank">guedes_1000@hotmail.com</a>></span> escreveu:
<div>
<div><br>
<blockquote style="border-left:1px #ccc solid; padding-left:1ex">
<div>
<div dir="ltr">Não fiz em poucas linhas, mas fis em poucos segundos: <a href="http://pastebin.com/DLdPwAkp" target="_blank">http://pastebin.com/DLdPwAkp</a><br>
<br>
<div>
<hr>
Date: Tue, 22 Apr 2014 15:09:22 -0300
<div>
<div><br>
From: <a href="mailto:guedes_1000@hotmail.com" target="_blank">guedes_1000@hotmail.com</a><br>
To: <a href="mailto:rio-pm@pm.org" target="_blank">rio-pm@pm.org</a><br>
Subject: Re: [Rio-pm] [GOLF] Descanso de Pascoa: Maior palindromo<br>
<br>
<div>Claro que esta. Mas nao consegui fazer o que o que o Bablos sugeriu em uma única linha.<br>
<br>
Vinícius Miasato <<a href="mailto:viniciusmiasato@gmail.com" target="_blank">viniciusmiasato@gmail.com</a>> escreveu:<br>
<br>
</div>
<div>
<div dir="ltr">
<div>
<div>Opa,<br>
<br>
</div>
parabéns por aceitar o desafio e levá-lo até o fim! Não sei se o código funciona, mas o jogo de GOLF ainda está de pé?<br>
<br>
</div>
atenciosamente,<br>
Vinícius Miasato<br>
</div>
<div><br>
<br>
<div>Em 22 de abril de 2014 13:13, Aureliano Guedes <span dir="ltr"><<a href="mailto:guedes_1000@hotmail.com" target="_blank">guedes_1000@hotmail.com</a>></span> escreveu:<br>
<blockquote style="border-left:1px #ccc solid; padding-left:1ex">
<div>
<div dir="ltr"><a href="http://ideone.com/LjvMRz" target="_blank">http://ideone.com/LjvMRz</a>
<div><br>
</div>
<div>4:30 rodando no dinossauro (AMD Athlon 1.6GHz, 2GB Ram)</div>
<div><br>
<div>
<div>
<hr>
Date: Thu, 17 Apr 2014 22:25:48 -0300<br>
From: <a href="mailto:guedes_1000@hotmail.com" target="_blank">guedes_1000@hotmail.com</a><br>
To: <a href="mailto:rio-pm@pm.org" target="_blank">rio-pm@pm.org</a><br>
Subject: Re: [Rio-pm] [GOLF] Descanso de Pascoa: Maior palindromo</div>
<div>
<div><br>
<br>
<div>Boa ideia. Vou tentar.<br>
<br>
Blabos de Blebe <<a href="mailto:blabos@gmail.com" target="_blank">blabos@gmail.com</a>> escreveu:<br>
<br>
</div>
<div>
<div dir="ltr">Que tal o menor palíndromo primo maior que time()?</div>
<div><br>
<br>
<div>2014-04-17 22:02 GMT-03:00 Aureliano Guedes <span dir="ltr"><<a href="mailto:guedes_1000@hotmail.com" target="_blank">guedes_1000@hotmail.com</a>></span>:<br>
<blockquote style="border-left:1px #ccc solid; padding-left:1ex">
<div>
<div>Pode ficar menor.<br>
say '906609'<br>
<br>
Tiago Peczenyj <<a href="mailto:tiago.peczenyj@gmail.com" target="_blank">tiago.peczenyj@gmail.com</a>> escreveu:<br>
<br>
</div>
<div>
<div>
<div>
<div dir="ltr">sub palindromo { <span style="font-family:arial,sans-serif; font-size:13px">906609 }</span></div>
<div><br>
<br>
<div>2014-04-17 21:45 GMT-03:00 Aureliano Guedes <span dir="ltr"><<a href="mailto:guedes_1000@hotmail.com" target="_blank">guedes_1000@hotmail.com</a>></span>:<br>
<blockquote style="border-left:1px #ccc solid; padding-left:1ex">
<div>
<div dir="ltr">Ola monges,
<div><br>
</div>
<div>Nos últimos meses tenho visto nosso grupo um pouco parado.</div>
<div>E como estamos em véspera de pascoa.</div>
<div>Proponho uma brincadeira.</div>
<div>Jogar golf com o Desafio do Maior Palíndromo.</div>
<div><br>
</div>
<div>O desafio é simples, achar o maior número palíndromo (ou seja, quando lido de trás pra frente continua o mesmo) que seja resultado de uma multiplicação de dois números de 3 dígitos.</div>
<div><br>
</div>
<div>O resultado deverá ser: 906609</div>
<div><br>
</div>
<div>Eis a minha tacada:</div>
<div><br>
</div>
<div>for(my$i=100;$i<1000;$i++){for(100..999){$_[0]=$_*$i if(($_*$i==reverse($_*$i))&&($_*$i>=$_[0]))}}say$_[0]</div>
</div>
</div>
<br>
_______________________________________________<br>
Rio-pm mailing list<br>
<a href="mailto:Rio-pm@pm.org" target="_blank">Rio-pm@pm.org</a><br>
<a href="http://mail.pm.org/mailman/listinfo/rio-pm" target="_blank">http://mail.pm.org/mailman/listinfo/rio-pm</a><br>
</blockquote>
</div>
<br>
<br clear="all">
<div><br>
</div>
-- <br>
Tiago B. Peczenyj<br>
Linux User #405772<br>
<br>
<a href="http://about.me/peczenyj" target="_blank">http://about.me/peczenyj</a> </div>
</div>
</div>
</div>
</div>
<br>
_______________________________________________<br>
Rio-pm mailing list<br>
<a href="mailto:Rio-pm@pm.org" target="_blank">Rio-pm@pm.org</a><br>
<a href="http://mail.pm.org/mailman/listinfo/rio-pm" target="_blank">http://mail.pm.org/mailman/listinfo/rio-pm</a><br>
</blockquote>
</div>
<br>
</div>
</div>
<br>
_______________________________________________ Rio-pm mailing list <a href="mailto:Rio-pm@pm.org" target="_blank">
Rio-pm@pm.org</a> <a href="http://mail.pm.org/mailman/listinfo/rio-pm" target="_blank">
http://mail.pm.org/mailman/listinfo/rio-pm</a><br>
_______________________________________________ Rio-pm mailing list <a href="mailto:Rio-pm@pm.org" target="_blank">
Rio-pm@pm.org</a> <a href="http://mail.pm.org/mailman/listinfo/rio-pm" target="_blank">
http://mail.pm.org/mailman/listinfo/rio-pm</a></div>
</div>
</div>
</div>
</div>
</div>
<br>
_______________________________________________<br>
Rio-pm mailing list<br>
<a href="mailto:Rio-pm@pm.org" target="_blank">Rio-pm@pm.org</a><br>
<a href="http://mail.pm.org/mailman/listinfo/rio-pm" target="_blank">http://mail.pm.org/mailman/listinfo/rio-pm</a><br>
</blockquote>
</div>
<br>
</div>
</div>
<br>
_______________________________________________ Rio-pm mailing list <a href="mailto:Rio-pm@pm.org" target="_blank">
Rio-pm@pm.org</a> <a href="http://mail.pm.org/mailman/listinfo/rio-pm" target="_blank">
http://mail.pm.org/mailman/listinfo/rio-pm</a><br>
_______________________________________________ Rio-pm mailing list <a href="mailto:Rio-pm@pm.org" target="_blank">
Rio-pm@pm.org</a> <a href="http://mail.pm.org/mailman/listinfo/rio-pm" target="_blank">
http://mail.pm.org/mailman/listinfo/rio-pm</a></div>
</div>
</div>
</div>
</div>
<br>
_______________________________________________<br>
Rio-pm mailing list<br>
<a href="mailto:Rio-pm@pm.org" target="_blank">Rio-pm@pm.org</a><br>
<a href="http://mail.pm.org/mailman/listinfo/rio-pm" target="_blank">http://mail.pm.org/mailman/listinfo/rio-pm</a><br>
</blockquote>
</div>
</div>
</div>
<br>
</div>
<br>
_______________________________________________<br>
Rio-pm mailing list<br>
<a href="mailto:Rio-pm@pm.org" target="_blank">Rio-pm@pm.org</a><br>
<a href="http://mail.pm.org/mailman/listinfo/rio-pm" target="_blank">http://mail.pm.org/mailman/listinfo/rio-pm</a><br>
</blockquote>
</div>
<br>
</div>
<br>
_______________________________________________ Rio-pm mailing list <a href="mailto:Rio-pm@pm.org" target="_blank">
Rio-pm@pm.org</a> <a href="http://mail.pm.org/mailman/listinfo/rio-pm" target="_blank">
http://mail.pm.org/mailman/listinfo/rio-pm</a></div>
</div>
</div>
<br>
_______________________________________________ Rio-pm mailing list <a href="mailto:Rio-pm@pm.org" target="_blank">
Rio-pm@pm.org</a> <a href="http://mail.pm.org/mailman/listinfo/rio-pm" target="_blank">
http://mail.pm.org/mailman/listinfo/rio-pm</a></div>
</div>
</div>
</div>
</div>
</div>
<br>
_______________________________________________<br>
Rio-pm mailing list<br>
<a href="mailto:Rio-pm@pm.org">Rio-pm@pm.org</a><br>
<a href="http://mail.pm.org/mailman/listinfo/rio-pm" target="_blank">http://mail.pm.org/mailman/listinfo/rio-pm</a><br>
</blockquote>
</div>
<br>
<br clear="all">
<div><br>
</div>
-- <br>
Bruno C. Buss<br>
<a href="http://www.brunobuss.net" target="_blank">http://www.brunobuss.net</a> </div>
</div>
</div>
</body>
</html>