Числа Гильберта определяются как положительные целые числа в форме 4n + 1
для n >= 0
. Первые несколько чисел Гильберта:
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
Последовательность чисел Гильберта задается последовательностью OEIS A016813 .
Связанная числовая последовательность, простые числа Гильберта, определяются как числа Гильберта H > 1
, которые не делятся на любое число Гильберта, k
такое что 1 < k < H
. Первые несколько простых чисел Гильберта:
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
Естественно, у OEIS есть и эта последовательность .
Учитывая целое число n
такое, что в 0 <= n <= 2^16
качестве входных данных выведите n
th простое число Гильберта.
Это код-гольф , поэтому применяются стандартные правила, и выигрывает самый короткий код в байтах.
Leaderboard
Фрагмент стека в нижней части этого поста создает таблицу лидеров из ответов а) в виде списка кратчайшего решения для каждого языка и б) в качестве общей таблицы лидеров.
Чтобы убедиться, что ваш ответ обнаружен, начните его с заголовка, используя следующий шаблон уценки:
## Language Name, N bytes
где N
размер вашего представления. Если вы улучшите свой счет, вы можете сохранить старые результаты в заголовке, вычеркнув их. Например:
## Ruby, <s>104</s> <s>101</s> 96 bytes
Если вы хотите включить в заголовок несколько чисел (например, потому что ваш результат равен сумме двух файлов или вы хотите перечислить штрафы за флаг интерпретатора отдельно), убедитесь, что фактический результат является последним числом в заголовке:
## Perl, 43 + 2 (-p flag) = 45 bytes
Вы также можете сделать имя языка ссылкой, которая будет отображаться во фрагменте кода:
## [><>](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>
Ответы:
Pyth, 21 байт
Попробуйте онлайн: демонстрация или тестовый набор
Объяснение:
источник
Haskell, 46 байтов
Анонимная функция.
Ядро
foldr(\a b->a:[x|x<-b,mod x a>0])[][5,9..]
, которое перебирает арифметическую прогрессию5,9,13,...
, удаляя кратные каждого из списка справа от него. Это приводит к бесконечному списку простых чисел Гильберта. Затем!!
принимаетn
элемент.Я пытался сделать
(\a b->a:[x|x<-b,mod x a>0])
бессмысленно, но не нашел более короткого пути.источник
foldr
в другой список понимания спасает два байса:([x|x<-[5,9..],all((>0).mod x)[5,9..x-1]]!!)
CJam,
36333223 байтаПопробуйте онлайн
Последняя версия на самом деле намного больше @ MartinBüttner, чем моя. Основная идея в предложенном им решении состоит в том, чтобы использовать два вложенных цикла для нахождения n-го значения, которое удовлетворяет условию. Я думал, что был умен, используя только один цикл в моем исходном решении, но оказалось, что добавленная логика стоит больше, чем я сэкономил, не используя второй цикл.
объяснение
источник
Минколанг 0,14 ,
463732 байтаЯ не осознавал, что госуб совершенно не нужен ...> _>
Попробуйте здесь и проверьте все тесты здесь .
объяснение
Регистр используется для хранения целевого индекса. Внешний цикл while вычисляет каждое число Гильберта и ведет некоторую бухгалтерию. Внутренний цикл while проверяет каждое число Гильберта на простоту. Если число Гильберта не является простым числом Гильберта, то цель увеличивается, так что внешний цикл while должен повторяться (как минимум) еще один раз, эффективно пропуская композиты Гильберта.
источник
Mathematica, 65 байт
Создает весь список и выбирает из него элемент.
источник
Рубин, 60 байт
Только проверяет главные факторы Гильберта.
источник
JavaScript (ES6), 73 байта
Просто проверяйте числа Гильберта одно за другим, пока мы не достигнем n-го простого Гильберта. Делимость на число Гильберта обрабатывается регулярным выражением.
источник
Matlab, 74
83байтаСпасибо Тому Карпентеру за удаление 9 байт!
Пример использования:
источник
Юлия, 73 байта
Спасибо Алексею Александровичу за сохранение 11 байт! При этом используется тот же алгоритм, что и в ответах Matlab и Ruby. Поскольку массивы Julia индексируются однозначно, это начинается с
f(1) == 5
.Моя первая попытка с использованием пакета Lazy - это 106 байт . Если вы планируете выполнить это в REPL, обязательно добавьте точки с запятой в конце строк, чтобы подавить бесконечный вывод. И позвоните,
Pkg.Add("Lazy")
если он еще не установлен.источник
n->(a=[x=5];while length(a)<n x+=4;all(k->mod(x,k)>0,a)&&push!(a,x)end;x)
endof
вместоlength
иx%k
вместоmod(x,k)
.