Bilangan Hilbert didefinisikan sebagai bilangan bulat positif 4n + 1
untuk formulir n >= 0
. Beberapa angka Hilbert pertama adalah:
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
Urutan nomor Hilbert diberikan oleh urutan OEIS A016813 .
Sebuah urutan nomor yang terkait, bilangan prima Hilbert, didefinisikan sebagai nomor Hilbert H > 1
yang tidak dapat dibagi oleh sejumlah Hilbert k
sehingga 1 < k < H
. Beberapa bilangan prima Hilbert pertama adalah:
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
Secara alami, OEIS juga memiliki urutan ini .
Diberikan bilangan bulat n
sehingga 0 <= n <= 2^16
sebagai input, output n
utama Hilbert.
Ini adalah kode-golf , jadi aturan standar berlaku, dan kode terpendek dalam byte akan menang.
Papan peringkat
Cuplikan Stack di bagian bawah posting ini menghasilkan leaderboard dari jawaban a) sebagai daftar solusi terpendek per bahasa dan b) sebagai leaderboard keseluruhan.
Untuk memastikan bahwa jawaban Anda muncul, silakan mulai jawaban Anda dengan tajuk utama, menggunakan templat Penurunan harga berikut:
## Language Name, N bytes
di mana N
ukuran kiriman Anda. Jika Anda meningkatkan skor Anda, Anda dapat menyimpan skor lama di headline, dengan mencoretnya. Contohnya:
## Ruby, <s>104</s> <s>101</s> 96 bytes
Jika Anda ingin memasukkan beberapa angka dalam tajuk Anda (mis. Karena skor Anda adalah jumlah dari dua file atau Anda ingin membuat daftar hukuman penterjemah secara terpisah), pastikan bahwa skor sebenarnya adalah angka terakhir di tajuk:
## Perl, 43 + 2 (-p flag) = 45 bytes
Anda juga dapat membuat nama bahasa menjadi tautan yang kemudian akan muncul di cuplikan:
## [><>](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>
Jawaban:
Pyth, 21 byte
Cobalah online: Demonstrasi atau Test Suite
Penjelasan:
sumber
Haskell, 46 byte
Fungsi anonim.
Inti adalah
foldr(\a b->a:[x|x<-b,mod x a>0])[][5,9..]
, yang iterate melalui perkembangan aritmatika5,9,13,...
, menghilangkan kelipatan masing-masing dari daftar di sebelah kanannya. Ini menghasilkan daftar bilangan prima Hilbert yang tak terbatas. Kemudian,!!
ambiln
elemen th.Saya telah mencoba membuat
(\a b->a:[x|x<-b,mod x a>0])
pointfree tetapi tidak menemukan cara yang lebih pendek.sumber
foldr
menjadi daftar pemahaman lain menghemat dua bye:([x|x<-[5,9..],all((>0).mod x)[5,9..x-1]]!!)
CJam,
36333223 byteCobalah online
Versi terbaru sebenarnya jauh lebih @ MartinBüttner daripada milik saya. Gagasan kunci dalam solusi yang disarankan adalah menggunakan dua loop bersarang untuk menemukan nilai ke-n yang memenuhi kondisi tersebut. Saya pikir saya menjadi pandai dengan hanya menggunakan satu loop dalam solusi asli saya, tetapi ternyata biaya tambahan logika lebih banyak daripada yang saya hemat dengan tidak menggunakan loop kedua.
Penjelasan
sumber
Minkolang 0,14 ,
463732 byteSaya tidak menyadari bahwa gosub sama sekali tidak perlu ...> _>
Coba di sini dan periksa semua test case di sini .
Penjelasan
Register digunakan untuk menyimpan indeks target. Lingkaran while luar menghitung setiap nomor Hilbert dan melakukan pembukuan. Loop sementara dalam memeriksa setiap nomor Hilbert untuk primality. Jika bilangan Hilbert bukan bilangan Hilbert prima, maka target bertambah sehingga loop sementara di luar harus mengulang (setidaknya) sekali lagi, secara efektif melewatkan komposit Hilbert.
sumber
Mathematica, 65 byte
Buat seluruh daftar dan pilih elemen dari itu.
sumber
Ruby, 60 byte
Hanya memeriksa faktor prima Hilbert.
sumber
JavaScript (ES6), 73 byte
Cukup periksa nomor Hilbert satu per satu sampai kita mencapai prime Hilbert ke-n. Dapat dibagi oleh nomor Hilbert ditangani oleh regex.
sumber
Matlab, 74
83byteTerima kasih kepada Tom Carpenter karena menghapus 9 byte!
Contoh penggunaan:
sumber
Julia, 73 byte
Terima kasih Alex A. untuk menghemat 11 byte! Ini menggunakan algoritma yang sama dengan jawaban Matlab dan Ruby. Karena array Julia diindeks satu, ini dimulai dengan
f(1) == 5
.Upaya pertama saya, menggunakan paket Malas, adalah 106 byte . Jika Anda berencana untuk menjalankan ini di REPL, pastikan untuk menambahkan titik koma ke ujung garis untuk menekan output yang tak terbatas. Dan hubungi
Pkg.Add("Lazy")
jika Anda belum menginstalnya.sumber
n->(a=[x=5];while length(a)<n x+=4;all(k->mod(x,k)>0,a)&&push!(a,x)end;x)
endof
bukanlength
danx%k
bukanmod(x,k)
.