Послідовність двійкової квадрати-діагоналі будується так:
- Візьміть послідовність додатних натуральних чисел:
1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, ...
Перетворити кожне число у двійкове:
1, 10, 11, 100, 101, 110, 111, 1000, 1001, 1010, 1011, 1100, 1101, 1110, 1111, 10000, 10001, ...
Об’єднайте їх:
11011100101110111100010011010101111001101111011111000010001 ...
Починаючи з цього
n=1
, формуйте квадрати зі збільшенням довжини сторони,n
які заповнюються зліва направо, зверху вниз елементами вищезазначеної послідовності:1
1 0 1 1
1 0 0 1 0 1 1 1 0
1 1 1 1 0 0 0 1 0 0 1 1 0 1 0 1
0 1 1 1 1 0 0 1 1 0 1 1 1 1 0 1 1 1 1 1 0 0 0 0 1
...
Візьміть діагональ (зверху зліва до праворуч) кожного квадрата:
1, 11, 100, 1011, 00111, ...
Перетворити в десятковий (ігноруючи провідні нулі):
1, 3, 4, 11, 7, ...
Завдання
Напишіть програму або функцію, яка виводить послідовність одним із наступних способів:
- Повертайте або друкуйте послідовність нескінченно.
- Дано введення
i
, повернення або друк першихi
елементів послідовності. - Дано введення
i
, поверніть або роздрукуйте цейi
елемент послідовності (або 0, або 1, індексований).
Будь ласка, вкажіть у своїй відповіді, який вихідний формат ви обрали.
Це код-гольф , найкоротша відповідь на кожній мові виграє.
Тестові кейси
Ось перші 50 елементів послідовності:
1,3,4,11,7,29,56,141,343,853,321,3558,8176,3401,21845,17129,55518,134717,151988,998642,1478099,391518,7798320,8530050,21809025,61485963,66846232,54326455,221064493,256373253,547755170,4294967295,1875876391,2618012644,24710258456,6922045286,132952028155,217801183183,476428761596,51990767390,687373028085,1216614609441,7677215985062,15384530216172,22714614479340,15976997237789,0,256145539974868,532024704777005,601357273478135
3m
їхn
?