Двійкові послідовності


23

Давши двійкове число A як вхід з d> 1 цифр, виведіть двійкове число B з d цифрами відповідно до наступних правил для знаходження n-ї цифри B:

  • Перша цифра B дорівнює нулю, якщо перша і друга цифри A рівні; інакше це одне.

  • Якщо 1 <n <d, то якщо (n-1) th, nth і (n + 1) цифри A рівні, то n-та цифра B дорівнює нулю; інакше це одне.

  • Dth цифра B дорівнює нулю, якщо (d-1) й dth цифри A рівні; інакше це одне.

Правила

Формат введення / виводу рядків / списку нормально. Іншим дозволеним способом введення / виводу є ціле число, за яким слідує число попередніх нулів (або наступне число попередніх нулів).

Зробіть свій код якомога коротшим.

Випробування

00 -> 00
01 -> 11
11 -> 00
010111100111 -> 111100111100
1000 -> 1100
11111111 -> 00000000
01010101 -> 11111111
1100 -> 0110

Вам слід було б почекати ще 10 хвилин, тоді ви отримали б шапку . Хороший виклик, хоча!
caird coinheringaahing

@cairdcoinheringaahing Я пам'ятаю ті минулого року ... о, добре. :-(
0WJYxW9FMN

2
Пропонований тестовий випадок: 1100 -> 0110(перші 2 цифри результату завжди однакові у всіх інших тестових випадках; ditto для останніх двох цифр)
Arnauld

Приємно бачити, що жоден рейтинг не був зроблений на цей виклик або на його двадцять п’ять відповідей. Молодці, всі!
0WJYxW9FMN

Відповіді:


7

Haskell, 59 58 54 байт

f s=[1-0^(a-b+a-c)^2|a:b:c:_<-scanr(:)[last s]$s!!0:s]

Спробуйте в Інтернеті!

f s=                        -- input is a list of 0 and 1
          s!!0:s            -- prepend the first and append the last number of s to s
      scanr(:)[last s]      --   make a list of all inits of this list
     a:b:c:_<-              -- and keep those with at least 3 elements, called a, b and c
    1-0^(a-b+a-c)^2         -- some math to get 0 if they are equal or 1 otherwise

Редагувати: @ Ørjan Johansen врятував 4 байти. Спасибі!


Якщо ви не заперечуєте про перехід до рядкового виводу, тоді "0110"!!(a+b+c)зберігається байт.
Лайконі

@Laikoni: Дякую, але я знайшов також байт у своїй математиці.
німі

2
[last s]можна перенести на scanrпочаткове значення.
Ørjan Johansen

Ого. inits (при імпорті); абс; якщо-то-інше; карта (візьміть 3); zipWith; takeWhile (not.null); шматки (з його імпортом) ... все гольф геть! чи є зал слави про гольф, десь і десь?
Чи буде Несс

7

Желе , 9 байт

.ịṚjṡ3E€¬

Спробуйте в Інтернеті!

I / O як список цифр.

Пояснення:

.ịṚjṡ3E€¬
.ịṚ       Get first and last element
   j      Join the pair with the input list, thus making a list [first, first, second, ..., last, last]
    ṡ3    Take sublists of length 3
      E€  Check if each has all its elements equal
        ¬ Logical NOT each

Майже те саме з моєю спробою : P
Leaky Nun

@LeakyNun досить просто дістати ідентичний код у більш легких викликах; p
Ерік the Outgolfer

2
Чи можете ви додати пояснення?
caird coinheringaahing

@cairdcoinheringaahing Ви, швидше за все, розумієте код , але я додаю це як орієнтир для всіх, поки Ерік не додасть його (якщо він є): .ị- Отримує елемент в індексі 0,5 . Оскільки підлогу (0,5) ≠ ceil (0,5) , повертає елементи в індексах 0 і 1 . Желе є одним з індексованих, таким чином 0 фактично захоплює останній елемент. обертає пару (тому що вони повертаються як last, first). Потім jприєднується до пари на вході і ṡ3розбиває її на фрагменти, що перекриваються довжиною 3. E€перевіряє (для кожного списку), чи всі елементи рівні, і ¬логічно заперечує кожен.
Містер Xcoder

6

05AB1E , 6 байт

¥0.ø¥Ā

Введення / виведення у формі бітових масивів.

Спробуйте в Інтернеті!

Як це працює

¥       Compute the forward differences of the input, yielding -1, 0, or 1 for each
        pair. Note that there cannot be two consecutive 1's or -1's.
 0.ø    Surround the resulting array with 0‘s.
    ¥   Take the forward differences again. [0, 0] (three consecutive equal 
        elements in the input) gets mapped to 0, all other pairs get mapped to a 
        non-zero value.
     Ā  Map non-zero values to 1.


5

Haskell , 66 61 59 байт

g t@(x:s)=map("0110"!!)$z(x:t)$z t$s++[last s]
z=zipWith(+)

Спробуйте в Інтернеті! Введення - це список нулів і одиниць, вихід - рядок. Приклад використання: g [0,1,0,1,1,1,1,0,0,1,1,1]врожайність "111100111100".


Попереднє 61 байтне рішення:

g s=["0110"!!(a+b+c)|(a,b,c)<-zip3(s!!0:s)s$tail s++[last s]]

Спробуйте в Інтернеті!


4

J , 26 14 байт

Заслуга рішення 05AB1E від Emigna

2=3#@=\{.,],{:

Спробуйте в Інтернеті!

Оригінальна спроба

2|2#@="1@|:@,,.@i:@1|.!.2]

Спробуйте в Інтернеті!

             ,.@i:@1              -1, 0, 1
                    |.!.2]         shift filling with 2
  2         ,                      add a row of 2s on top
         |:                        transpose
   #@="1                           count unique elements in each row
2|                                 modulo 2

Розумний спосіб виготовлення інфіксів з 3 на початку та в кінці.
Коул


2

Лушпиння , 15 11 байт

Ẋȯ¬EėSJ§e←→

Вводиться як список, спробуйте в Інтернеті! Або спробуйте цю, яка використовує рядки для вводу-виводу.

Пояснення

Ẋ(¬Eė)SJ§e←→ -- implicit input, for example [1,0,0,0]
      SJ     -- join self with the following
        §e   --   listify the
                  first and
                  last element: [1,0]
             -- [1,1,0,0,0,0]
Ẋ(   )       -- with each triple (eg. 1 0 0) do the following:
    ė        --   listify: [1,1,0]
   E         --   are all equal: 0
  ¬          --   logical not: 1
             -- [1,1,0,0]

2

Желе , 8 байт

I0;;0In0

Введення / виведення у формі бітових масивів.

Спробуйте в Інтернеті!

Як це працює

I0;;0In0  Main link. Argument: A (bit array of length d)

I         Increments; compute the forward differences of all consecutive elements
          of A, yielding -1, 0, or 1 for each pair. Note that there cannot be
          two consecutive 1's or -1's.
 0;       Prepend a 0 to the differences.
   ;0     Append a 0 to the differences.
     I    Take the increments again. [0, 0] (three consecutive equal elements in A)
          gets mapped to 0, all other pairs get mapped to a non-zero value.
      n0  Perform not-equal comparison with 0, mapping non-zero values to 1.

Я прийшов до смішної альтернативи, можливо, ви можете з цього I0,0jI¬¬
надихнути

2

JavaScript (ES6), 45 байт

Вводить дані як масив символів. Повертає масив цілих чисел.

a=>a.map((v,i)=>(i&&v^p)|((p=v)^(a[i+1]||v)))

Тестові справи

Прокоментував

a =>                  // given the input array a
  a.map((v, i) =>     // for each digit v at position i in a:
    (                 //   1st expression:
      i &&            //     if this is not the 1st digit:
           v ^ p      //       compute v XOR p (where p is the previous digit)
    ) | (             //   end of 1st expression; bitwise OR with the 2nd expression:
      (p = v) ^       //     update p and compute v XOR:
      (a[i + 1] ||    //       the next digit if it is defined
                   v) //       v otherwise (which has no effect, because v XOR v = 0)
    )                 //   end of 2nd expression
  )                   // end of map()


1

Желе , 16 байт

ḣ2W;ṡ3$;ṫ-$W$E€¬

Спробуйте в Інтернеті!

Я збирався в гольф це, але Ерік вже має коротше рішення, і шахта для гольфу просто наблизить шахту до його. Я все ще займаюся гольфом, але не оновлюсь, якщо не зможу його обіграти або знайти унікальну ідею.

Пояснення

ḣ2W;ṡ3$;ṫ-$W$E€¬  Main Link
ḣ2                First 2 elements
  W               Wrapped into a list (depth 2)
   ;              Append
    ṡ3$           All overlapping blocks of 3 elements
       ;          Append
        ṫ-$W$     Last two elements wrapped into a list
             E€   Are they all equal? For each
               ¬  Vectorizing Logical NOT


1

Perl 5 , 62 + 1 ( -n) = 63 байти

s/^.|.$/$&$&/g;for$t(0..y///c-3){/.{$t}(...)/;print$1%111?1:0}

Спробуйте в Інтернеті!


Скорочене до 49 байт: Спробуйте в Інтернеті!
Дада

Ви повинні опублікувати це як відповідь. Я не хочу брати кредит за вашу роботу. Ця s;..$;конструкція в кінці витончена. Мені доведеться пам'ятати про це.
Xcali


1

Japt , 14 13 12 байт

Частково порціонується з розчину желейника Денніса. Введення та вихід - це масиви цифр.

ä- pT äaT mg

Збережено байт завдяки ETHproductions.

Спробуй це


Пояснення

Неявне введення масиву U. ä-отримує дельти масиву. pTнатискає 0 до кінця масиву. äaTПерший додає ще 0 до початку масиву, перш ніж отримати абсолютні дельти. mgвідображає елементи масиву, повертаючи знак кожного елемента як -1 для від’ємних чисел, 0 для 0 або 1 для додатних чисел.


Хм, мені цікаво, чи є хороший спосіб зробити метод, який ставить елемент на початку та в кінці масиву, як у відповіді 05AB1E. Я думаю, що це зробило б його на 1 байт коротшим ...
ETHproductions

@ETHproductions, для лайків A.ä()яких передчуває другий аргумент, ви можете додати 3-й аргумент, який додається. Таким чином, у цьому випадку pT äaTможе стати äaTTдля збереження 2 байти.
Shaggy


1

J, 32 байт

B=:2&(+./\)@({.,],{:)@(2&(~:/\))

Як це працює:

B=:                              | Define the verb B
                       2&(~:/\)  | Put not-equals (~:) between adjacent elements of the array, making a new one
            ({.,],{:)            | Duplicate the first and last elements
   2&(+./\)                      | Put or (+.) between adjacent elements of the array

Я залишив деякі @s та круглі дужки, які просто переконайтесь, що це добре поєднується.

Покроковий приклад:

    2&(~:/\) 0 1 0 1 1 1 1 0 0 1 1 1
1 1 1 0 0 0 1 0 1 0 0

    ({.,],{:) 1 1 1 0 0 0 1 0 1 0 0
1 1 1 1 0 0 0 1 0 1 0 0 0

    2&(+./\) 1 1 1 1 0 0 0 1 0 1 0 0 0
1 1 1 1 0 0 1 1 1 1 0 0

    B 0 1 0 1 1 1 1 0 0 1 1 1
1 1 1 1 0 0 1 1 1 1 0 0

0

Сітківка , 35 байт

(.)((?<=(?!\1)..)|(?=(?!\1).))?
$#2

Спробуйте в Інтернеті! Посилання включає тестові випадки. Пояснення: Регекс починається зі співставлення кожної вхідної цифри по черзі. Група захоплення намагається співставити іншу цифру до або після розглядуваної цифри. Потім ?суфікс дозволяє зйомку відповідати 0 або 1 раз; $#2перетворює це у вихідну цифру.


0

Pyth , 15 байт

mtl{d.:++hQQeQ3

Спробуйте тут!

Як варіант:

  • mtl{d.:s+hQeBQ3.
  • .aM._M.+++Z.+QZ.

Це попереджує перший елемент і додає останній елемент, потім отримує всі перекриваються підрядки довжиною 3, і, нарешті, приймає кількість різних елементів у кожному підписку та зменшує його. Цей безлад був зроблений на мобільному опівночі, тому я не здивуюсь, якщо є легкі гольфи.


0

Гая , 9 байт

ọ0+0¤+ọ‼¦

Спробуйте в Інтернеті!

Пояснення

ọ0 + 0¤ + ọ‼ ¦ ~ Програма, що приймає один аргумент, список двійкових цифр.

ọ ~ Дельти.
 0+ ~ Додайте 0.
   0 ~ Натисніть нуль до стеку.
    ¤ ~ Поміняйте своєю версією два аргументи на стеку.
     + ~ Concatenate (останні три байти в основному додають 0).
      ọ ~ Дельти.
        ¦ ~ І для кожного елемента N:
       ‼ ~ Вихід 1, якщо N ≠ 0, інакше 0.

Гая , 9 байт

ọ0¤;]_ọ‼¦

Спробуйте в Інтернеті!


0

C , 309 байт

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main(int argc,char** argv){int d=strlen(argv[1]);char b[d + 1];char a[d + 1];strcpy(a, argv[1]);b[d]='\0';b[0]=a[0]==a[1]?'0':'1';for(int i=1;i<d-1;i++){b[i]=a[i]==a[i+1]&&a[i]==a[i - 1]?'0':'1';}b[d-1]=a[d-1]==a[d-2]?'0':'1';printf("%s\n",b);}

Не зовсім мова, яка підходить для гри в гольф, але відповідь вартий не менше. Спробуйте тут !

Пояснення

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main(int argc, char** argv) {
    /* Find the number of digits in number (taken in as a command line argument) */
    int d = strlen(argv[1]);

    /* d + 1 to account for d digits plus the null character */
    char b[d + 1];
    char a[d + 1];

    /* Saves having to type argv[1] every time we access it. */
    strcpy(a, argv[1]);

    /* Set the null character, so printf knows where our string ends. */
    b[d] = '\0';

    /* First condition */
    /* For those not familiar with ternary operators, this means b[0] is equal to '0' if a[0] equals a[1] and '1' if they aren't equal. */
    b[0] = a[0] == a[1] ? '0' : '1';

    /* Second condition */
    for(int i = 1; i < d - 1; i++) {
        b[i] = a[i] == a[i+1] && a[i] == a[i - 1] ? '0' : '1';
    }

    /* Third condition */
    b[d - 1] = a[d - 1] == a[d - 2] ? '0' : '1';

    /* Print the answer */
    printf("%s\n", b);
}

Ласкаво просимо до PPCG :)
Shaggy

0

APL + WIN, 29 байт

(↑b),(×3|3+/v),¯1↑b←×2|2+/v←⎕

Запрошує ввести екран як вектор цифр і виводить вектор цифр.

Пояснення

b←×2|2+/v signum of 2 mod sum of successive pairs of elements

×3|3+/v signum of 3 mod sum of successive triples of elements

(↑b),...., ¯1↑b concatenate first and last elements of b for end conditions

0

SNOBOL4 (CSNOBOL4) , 273 байти

	I =INPUT
	D =SIZE(I)
N	P =P + 1
	EQ(P,1)	:S(S)
	EQ(P,D)	:S(E)
	I POS(P - 2) LEN(2) . L
	I POS(P - 1) LEN(2) . R
T	Y =IDENT(L,R) Y 0	:S(C)
	Y =Y 1
C	EQ(P,D) :S(O)F(N)
S	I LEN(1) . L
	I POS(1) LEN(1) . R :(T)
E	I RPOS(2) LEN(1) . L
	I RPOS(1) LEN(1) . R :(T)
O	OUTPUT =Y
END

Спробуйте в Інтернеті!

	I =INPUT			;* read input
	D =SIZE(I)			;* get the string length
N	P =P + 1			;* iNcrement step; all variables initialize to 0/null string
	EQ(P,1)	:S(S)			;* if P == 1 goto S (for Start of string)
	EQ(P,D)	:S(E)			;* if P == D goto E (for End of string)
	I POS(P - 2) LEN(2) . L		;* otherwise get the first two characters starting at n-1
	I POS(P - 1) LEN(2) . R		;* and the first two starting at n
T	Y =IDENT(L,R) Y 0	:S(C)	;* Test if L and R are equal; if so, append 0 to Y and goto C
	Y =Y 1				;* otherwise, append 1
C	EQ(P,D) :S(O)F(N)		;* test if P==D, if so, goto O (for output), otherwise, goto N
S	I LEN(1) . L			;* if at start of string, L = first character
	I POS(1) LEN(1) . R :(T)	;* R = second character; goto T
E	I RPOS(2) LEN(1) . L		;* if at end of string, L = second to last character
	I RPOS(1) LEN(1) . R :(T)	;* R = last character; goto T
O	OUTPUT =Y			;* output
END


Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.