Les nombres de Hilbert sont définis comme des entiers positifs de la forme 4n + 1
pour n >= 0
. Les premiers nombres de Hilbert sont:
1, 5, 9, 13, 17, 21, 25, 29, 33, 37, 41, 45, 49, 53, 57, 61, 65, 69, 73, 77, 81, 85, 89, 93, 97
La séquence des nombres de Hilbert est donnée par la séquence OEIS A016813 .
Une séquence de nombres apparentés, les nombres premiers de Hilbert, sont définis comme les nombres de Hilbert H > 1
qui ne sont pas divisibles par un nombre de Hilbert k
tel que 1 < k < H
. Les premiers nombres premiers de Hilbert sont:
5, 9, 13, 17, 21, 29, 33, 37, 41, 49, 53, 57, 61, 69, 73, 77, 89, 93, 97, 101, 109, 113, 121, 129, 133, 137, 141, 149, 157, 161, 173, 177, 181, 193, 197
Naturellement, OEIS a également cette séquence .
Étant donné un entier n
tel qu'en 0 <= n <= 2^16
entrée, sortez le n
premier Hilbert premier.
Il s'agit de code-golf , donc les règles standard s'appliquent et le code le plus court en octets l'emporte.
Classement
L'extrait de pile au bas de cet article génère le classement à partir des réponses a) comme une liste des solutions les plus courtes par langue et b) comme un classement général.
Pour vous assurer que votre réponse s'affiche, veuillez commencer votre réponse avec un titre, en utilisant le modèle Markdown suivant:
## Language Name, N bytes
où N
est la taille de votre soumission. Si vous améliorez votre score, vous pouvez conserver les anciens scores dans le titre, en les barrant. Par exemple:
## Ruby, <s>104</s> <s>101</s> 96 bytes
Si vous souhaitez inclure plusieurs nombres dans votre en-tête (par exemple, parce que votre score est la somme de deux fichiers ou que vous souhaitez répertorier les pénalités de drapeau d'interprète séparément), assurez-vous que le score réel est le dernier numéro de l'en-tête:
## Perl, 43 + 2 (-p flag) = 45 bytes
Vous pouvez également faire du nom de la langue un lien qui apparaîtra ensuite dans l'extrait de code:
## [><>](http://esolangs.org/wiki/Fish), 121 bytes
<style>body { text-align: left !important} #answer-list { padding: 10px; width: 290px; float: left; } #language-list { padding: 10px; width: 290px; float: left; } table thead { font-weight: bold; } table td { padding: 5px; }</style><script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <link rel="stylesheet" type="text/css" href="//cdn.sstatic.net/codegolf/all.css?v=83c949450c8b"> <div id="language-list"> <h2>Shortest Solution by Language</h2> <table class="language-list"> <thead> <tr><td>Language</td><td>User</td><td>Score</td></tr> </thead> <tbody id="languages"> </tbody> </table> </div> <div id="answer-list"> <h2>Leaderboard</h2> <table class="answer-list"> <thead> <tr><td></td><td>Author</td><td>Language</td><td>Size</td></tr> </thead> <tbody id="answers"> </tbody> </table> </div> <table style="display: none"> <tbody id="answer-template"> <tr><td>{{PLACE}}</td><td>{{NAME}}</td><td>{{LANGUAGE}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr> </tbody> </table> <table style="display: none"> <tbody id="language-template"> <tr><td>{{LANGUAGE}}</td><td>{{NAME}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr> </tbody> </table><script>var QUESTION_ID = 65895; var ANSWER_FILTER = "!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe"; var COMMENT_FILTER = "!)Q2B_A2kjfAiU78X(md6BoYk"; var OVERRIDE_USER = 45941; var answers = [], answers_hash, answer_ids, answer_page = 1, more_answers = true, comment_page; function answersUrl(index) { return "https://api.stackexchange.com/2.2/questions/" + QUESTION_ID + "/answers?page=" + index + "&pagesize=100&order=desc&sort=creation&site=codegolf&filter=" + ANSWER_FILTER; } function commentUrl(index, answers) { return "https://api.stackexchange.com/2.2/answers/" + answers.join(';') + "/comments?page=" + index + "&pagesize=100&order=desc&sort=creation&site=codegolf&filter=" + COMMENT_FILTER; } function getAnswers() { jQuery.ajax({ url: answersUrl(answer_page++), method: "get", dataType: "jsonp", crossDomain: true, success: function (data) { answers.push.apply(answers, data.items); answers_hash = []; answer_ids = []; data.items.forEach(function(a) { a.comments = []; var id = +a.share_link.match(/\d+/); answer_ids.push(id); answers_hash[id] = a; }); if (!data.has_more) more_answers = false; comment_page = 1; getComments(); } }); } function getComments() { jQuery.ajax({ url: commentUrl(comment_page++, answer_ids), method: "get", dataType: "jsonp", crossDomain: true, success: function (data) { data.items.forEach(function(c) { if (c.owner.user_id === OVERRIDE_USER) answers_hash[c.post_id].comments.push(c); }); if (data.has_more) getComments(); else if (more_answers) getAnswers(); else process(); } }); } getAnswers(); var SCORE_REG = /<h\d>\s*([^\n,<]*(?:<(?:[^\n>]*>[^\n<]*<\/[^\n>]*>)[^\n,<]*)*),.*?(\d+)(?=[^\n\d<>]*(?:<(?:s>[^\n<>]*<\/s>|[^\n<>]+>)[^\n\d<>]*)*<\/h\d>)/; var OVERRIDE_REG = /^Override\s*header:\s*/i; function getAuthorName(a) { return a.owner.display_name; } function process() { var valid = []; answers.forEach(function(a) { var body = a.body; a.comments.forEach(function(c) { if(OVERRIDE_REG.test(c.body)) body = '<h1>' + c.body.replace(OVERRIDE_REG, '') + '</h1>'; }); var match = body.match(SCORE_REG); if (match) valid.push({ user: getAuthorName(a), size: +match[2], language: match[1], link: a.share_link, }); else console.log(body); }); valid.sort(function (a, b) { var aB = a.size, bB = b.size; return aB - bB }); var languages = {}; var place = 1; var lastSize = null; var lastPlace = 1; valid.forEach(function (a) { if (a.size != lastSize) lastPlace = place; lastSize = a.size; ++place; var answer = jQuery("#answer-template").html(); answer = answer.replace("{{PLACE}}", lastPlace + ".") .replace("{{NAME}}", a.user) .replace("{{LANGUAGE}}", a.language) .replace("{{SIZE}}", a.size) .replace("{{LINK}}", a.link); answer = jQuery(answer); jQuery("#answers").append(answer); var lang = a.language; lang = jQuery('<a>'+lang+'</a>').text(); languages[lang] = languages[lang] || {lang: a.language, lang_raw: lang.toLowerCase(), user: a.user, size: a.size, link: a.link}; }); var langs = []; for (var lang in languages) if (languages.hasOwnProperty(lang)) langs.push(languages[lang]); langs.sort(function (a, b) { if (a.lang_raw > b.lang_raw) return 1; if (a.lang_raw < b.lang_raw) return -1; return 0; }); for (var i = 0; i < langs.length; ++i) { var language = jQuery("#language-template").html(); var lang = langs[i]; language = language.replace("{{LANGUAGE}}", lang.lang) .replace("{{NAME}}", lang.user) .replace("{{SIZE}}", lang.size) .replace("{{LINK}}", lang.link); language = jQuery(language); jQuery("#languages").append(language); } }</script>
Réponses:
Pyth, 21 octets
Essayez-le en ligne: démonstration ou suite de tests
Explication:
la source
Haskell, 46 octets
Une fonction anonyme.
Le noyau est
foldr(\a b->a:[x|x<-b,mod x a>0])[][5,9..]
, qui itère à travers la progression arithmétique5,9,13,...
, en supprimant les multiples de chacun de la liste à sa droite. Cela produit la liste infinie des nombres premiers de Hilbert. Ensuite,!!
prend len
th élément.J'ai essayé de faire sans
(\a b->a:[x|x<-b,mod x a>0])
point mais je n'ai pas trouvé de moyen plus court.la source
foldr
en une autre compréhension de la liste sauve deux byes:([x|x<-[5,9..],all((>0).mod x)[5,9..x-1]]!!)
CJam,
36333223 octetsEssayez-le en ligne
La dernière version est en réalité bien plus @ MartinBüttner que la mienne. L'idée clé de sa solution suggérée est d'utiliser deux boucles imbriquées pour trouver la nième valeur qui remplit la condition. Je pensais que j'étais intelligent en n'utilisant qu'une seule boucle dans ma solution d'origine, mais il s'avère que la logique ajoutée coûte plus cher que ce que j'ai économisé en n'utilisant pas une deuxième boucle.
Explication
la source
Minkolang 0,14 ,
463732 octetsJe ne savais pas que le gosub était totalement inutile ...> _>
Essayez-le ici et vérifiez tous les cas de test ici .
Explication
Le registre est utilisé pour stocker l'index cible. La boucle while externe calcule chaque nombre de Hilbert et effectue une certaine comptabilité. La boucle while intérieure vérifie la primauté de chaque nombre Hilbert. Si un nombre de Hilbert n'est pas un nombre premier de Hilbert, alors la cible est incrémentée de sorte que la boucle while externe doit se répéter (au moins) une fois de plus, en ignorant efficacement les composites Hilbert.
la source
Mathematica, 65 octets
Génère la liste entière et en sélectionne l'élément.
la source
Rubis, 60 octets
Vérifie uniquement les facteurs premiers de Hilbert.
la source
JavaScript (ES6), 73 octets
Il suffit de vérifier les numéros de Hilbert un par un jusqu'à ce que nous atteignions le nième nombre de Hilbert. La divisibilité par nombre de Hilbert est gérée par l'expression régulière.
la source
Matlab, 74
83octetsMerci à Tom Carpenter d'avoir supprimé 9 octets!
Exemple d'utilisation:
la source
Julia, 73 octets
Merci Alex A. pour avoir économisé 11 octets! Cela utilise le même algorithme que les réponses Matlab et Ruby. Étant donné que les tableaux Julia sont à un index, cela commence par
f(1) == 5
.Ma première tentative, en utilisant le package Lazy, est de 106 octets . Si vous prévoyez d'exécuter cela dans le REPL, assurez-vous d'ajouter des points-virgules aux extrémités des lignes pour supprimer la sortie infinie. Et appelez
Pkg.Add("Lazy")
si vous ne l'avez pas déjà installé.la source
n->(a=[x=5];while length(a)<n x+=4;all(k->mod(x,k)>0,a)&&push!(a,x)end;x)
endof
au lieu delength
etx%k
au lieu demod(x,k)
.