Введение (может быть проигнорировано)
Размещать все положительные числа в обычном порядке (1, 2, 3, ...) немного скучно, не правда ли? Итак, вот серия проблем, связанных с перестановками (перестановками) всех положительных чисел. Это третья задача в этой серии (ссылки на первую и вторую задачи).
В этой задаче мы упорядочим натуральные числа в строках возрастающей длины таким образом, чтобы сумма каждой строки была простым числом. Что меня действительно удивляет, так это то, что каждое натуральное число имеет место в этом расположении. Номера не пропущены!
Эта визуализация этого расположения выглядит следующим образом:
row numbers sum
1 1 1
2 2 3 5
3 4 5 8 17
4 6 7 9 15 37
5 10 11 12 13 21 67
6 14 16 17 18 19 23 107
etc.
Мы можем прочитать элементы из строк в этом треугольнике. Первые 20 элементов: 1, 2, 3, 4, 5, 8, 6 , 7, 9, 15, 10, 11, 12, 13, 21, 14, 16, 17, 18, 19 ( да, есть песня New Order, спрятанная в этой последовательности ).
Поскольку это задача «чистой последовательности», задача состоит в том, чтобы вывести для заданного качестве входных данных, где равно A162371 .
задача
Для целочисленного ввода выведите в целочисленном формате.
определяется как й элемент самой ранней лексикографической перестановки натуральных чисел, такой, что при рассмотрении в виде треугольника, читаемого по строкам, при n> 1 суммы строк являются простыми числами. Поскольку первый лексикографическом перестановки натуральных чисел начинается с 1, ( 1 ) равно 1. Следует отметитьчто по этому определению а ( 1 ) = 1 и ( 1 ) являетсянеобязан быть простым. Это последовательность OEISA162371.
Примечание: здесь предполагается индексирование на основе 1; Вы можете использовать индексирование на основе 0, поэтому и т. д. Пожалуйста, укажите это в своем ответе, если вы решите использовать это.
Контрольные примеры
Input | Output
---------------
1 | 1
5 | 5
20 | 19
50 | 50
78 | 87
123 | 123
1234 | 1233
3000 | 3000
9999 | 9999
29890 | 29913
правила
- Вход и выход являются целыми числами (ваша программа должна по крайней мере поддерживать вход и выход в диапазоне от 1 до 32767)
- Неверный ввод (0, значения с плавающей запятой, строки, отрицательные значения и т. Д.) Может привести к непредсказуемому выводу, ошибкам или (не) определенному поведению.
- Применяются правила ввода / вывода по умолчанию .
- Лазейки по умолчанию запрещены.
- Это код-гольф , поэтому самые короткие ответы в байтах выигрывают
Ответы:
Желе , 32 байта
Попробуйте онлайн! - очень медленно, поскольку сначала строится n строк, для более быстрой версии, которая при 37 байтах не пробует это .
источник
Perl 6 ,
8077 байтПопробуйте онлайн!
Объяснение:
источник
Haskell ,
122120 байтовПопробуйте онлайн!(имеет дополнительные 2 байта для
f=
)РЕДАКТИРОВАТЬ: теперь использует индексирование на основе 0, чтобы сохранить 2 байта. Спасибо @wastl за то, что указал на это, я, должно быть, пропустил это в ОП.
Это было очень весело писать! Вспомогательная функция
%
принимает длинуl
и список значений, которые она может использоватьa
. Возвращает бесконечный список значений для последовательности. Длина на единицу меньше длины текущей строки треугольника, а список бесконечен и предварительно отсортирован. Сначала мы просто выводим первыеl
значения из,a
а затем просматриваем оставшиеся a, пока не найдем первое (наименьшее) значение, которое делает сумму простой. Мы разбиваем список вокруг этого значения, используяspan
и некоторые сопоставления с образцом. Теперь все, что нам нужно сделать, это получить это новое значение и повторить со следующей длиной строкиl+1
и оставшимися значениями вa
. Для окончательного результата мы добавляем 1 (особый случай для n = 0) и индексируем в него с помощью!!
.источник
0:
как состояние вызова, вы можете использовать индексирование на основе 0.JavaScript (ES6),
111110 байтПопробуйте онлайн!
источник
Желе , 46 байт
Попробуйте онлайн!
Тайм-аут для больших n на tio, но работает там для всех, кроме двух последних примеров.
источник
Lua ,
242228226211 байтПопробуйте онлайн!
источник