Представьте себе перечисление элементов ромба, которые растут [1],[1,3,1],[1,3,5,3,1],…
(только нечетные числа, которые хорошо выровнены). Это будет выглядеть следующим образом, обратите внимание, что вы всегда начинаете перечисление с 1
:
01
1 02 03 04
1 2 3 4 05 06 07 08 09 …
5 10 11 12
13
(1) (1,3,1) (1,3,5,3,1) (1,3,5,7,5,3,1) …
Теперь, если вы начнете суммировать столбцы ( [1],[2],[1,3,5],[4],[5],[2,6,10],…
), вы получите последовательность ромбов . Это первые 100 элементов указанной последовательности:
1,2,9,4,5,18,35,24,9,10,33,60,91,70,45,16,17,54,95,140,189,154,115,72,25,26,81,140,203,270,341,288,231,170,105,36,37,114,195,280,369,462,559,484,405,322,235,144,49,50,153,260,371,486,605,728,855,754,649,540,427,310,189,64,65,198,335,476,621,770,923,1080,1241,1110,975,836,693,546,395,240,81,82,249,420,595,774,957,1144,1335,1530,1729,1564,1395,1222,1045,864,679,490,297,100
IO
Вы можете выбрать один из этих трех методов ввода / вывода (вам не нужно обрабатывать неправильные вводы):
- Учитывая целое число n, выведите n- й элемент в этой последовательности (0- или 1-индексированный, на ваш выбор)
- Учитывая целое число n, выведите первые n элементов этой последовательности
- Распечатать / вернуть последовательность до бесконечности
Testcases
Пожалуйста, обратитесь к первым 100 терминам выше, вот несколько больших примеров (с 1 индексированием):
101 -> 101
443 -> 1329
1000 -> 49000
1984 -> 164672
2017 -> 34289
2018 -> 30270
3000 -> 153000
JavaScript (ES7),
4241 байтСохранено 1 байт благодаря @ovs
0 индексированные. Выражение закрытой формы, полученное из A004737 .
Контрольные примеры
Показать фрагмент кода
источник
Befunge,
6260 байтПопробуйте онлайн!
объяснение
Мы начнем с чтения одноэлементного номера элемента n из стандартного ввода и сохранения дубликата.
Затем мы определяем, в каком ромбе мы находимся, подсчитывая целое число r до
r*r >= n
.Смещение столбца от правой стороны ромба, с , есть
r*r - n
.Чтобы получить это смещение, отраженное вокруг центральной оси, мы проверяем, если
c >= r
.И если это так, то отраженный с становится
r*2 - 2 - c
.Как только мы получим отраженное c , сумма столбца будет просто
(c*2 + 1) * n
.источник
APL (Dyalog) , 18 байт
Попробуйте онлайн!
источник
Желе , 8 байт
Попробуйте онлайн!
Как это работает
источник