Штифти роз'єму DVI


23

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

Існує три основні типи роз'ємів DVI : DVI-A (аналоговий), DVI-D (цифровий) та DVI-I (інтегрований). Крім того, існують односмугові та дволанкові версії роз'ємів DVI-D і DVI-I. Кожен з цих п'яти різних роз'ємів використовує різний набір штифтів.

З огляду на один з A, D1, D2, I1, в I2якості ідентифікатора типу роз'єму, роздрукуйте відповідний ASCII уявлення його контактів:

A:
#   #  # # #       # #
=====  # # #          
#   #  # #         # #

D1:
       # # #     # # #
=====  # # #     # # #
       # # #     # # #

D2:
       # # # # # # # #
=====  # # # # # # # #
       # # # # # # # #

I1:
#   #  # # #     # # #
=====  # # #     # # #
#   #  # # #     # # #

I2:
#   #  # # # # # # # #
=====  # # # # # # # #
#   #  # # # # # # # #

( X:Рядки не є частиною виводу, слід надрукувати лише 3 рядки.)

Ви можете написати програму або функцію, взявши вхід через STDIN, ARGV або аргумент функції. Вихід повинен бути надрукований в STDOUT з додатковою подачею рядків.

Ви можете або не включати пробіли у другому рядку Aз'єднувача. Ви не повинні використовувати додаткові провідні чи кінцеві місця деінде.

Це кодовий гольф, тому найкоротша відповідь (у байтах) виграє.


Чи можу я вимагати, щоб введення було оточене цитатами, наприклад "I1"замість I1?
Клавдіу

Чи дозволені пробіли на інших лініях?
gone_native

1
@Claudiu Nope, вибач.
Мартін Ендер

@gone_native Також ні, вибачте (додасть це до публікації).
Мартін Ендер

Відповіді:


3

CJam, 79 70 байт

Натхненний відповіддю нутки . Це також гарантує відсутність проміжків білого кольору (крім другого рядка)

"VF­wGC}*D"176b6b" DG1A="f=r'1+2<"  "aer{_s" ="&\"# "?}%s23/Wf<N*

Використовуйте це посилання, щоб скопіювати код у вигляді символів SE-смужок.

У діапазоні ASCII, який не можна друкувати, є 5 символів, але знаходяться в байті (код ASCII 255)

Як це працює :

"VF­wGC}*D"176b6b" DG1A="f=              "This effectively results into this string:"
                                        "D  D GGG11AGG=====  GGG11AAAD  D GGA11AGG";
r'1+2<                                  "Read the input, convert A to A1";
      "  "er                            "Replace the occurrences of above two characters"
                                        "with double space '  '";
            {_s" ="&\"# "?}%s           "Convert every non = and space character to '# '";
                             23/        "Divide the string into parts of 23 characters";
                                Wf<     "String last character from above parts";
                                   N*   "Join with new line";

Спробуйте його онлайн тут


16

Perl - 100 91 (включаючи 1 прапор)

Використовує ідеї нутків щодо використання -pта скорочення подвійних пробілів. Також спрощене усунення пробілів.

#!perl -p
$x=$_|" qb";$_="dbd xxxqqqax#
=====bxxxqqqaaa!dbd xxaqqqax#";s/[$x]/  /g;s/\w/# /g;s/ !/
/

Вхід походить від stdin і повинен містити лише тип з'єднувача без зворотного нового рядка.


Попередній:

$x=shift|" q";$_="d  d xxxqqqaxx
=====  xxxqqqaaa
d  d xxaqqqaxx";s/[$x]/  /g;s/\w/# /g;s/ $//mg;say

Бере аргумент командного рядка. Безголівки:

# Read argument, transform A->aq, I1->iq, I2->is, D1->dq, D2->ds
$x=shift|" q";

# String compacted
$_ = "d  d xxxqqqaxx
=====  xxxqqqaaa
d  d xxaqqqaxx";

# Clear any pins with matching char in input
s/[$x]/  /g;
# Convert rest to '#'
s/\w/# /g;
# Eliminate trailing spaces
s/ $//mg;
say

2
Геніальна ідея для обробки параметра. Ви все ще можете зберегти 2 байти, додавши $x=shift|" qb"та замінивши bв шаблоні 3 випадки подвійного простору . Також зміна вхідної обробки на '-p' дає 7 додаткових (мінус прапор): $x=$_|""і немає потреби в остаточному say.
nutki

@nutki - Дякую, я пропустив це!
gone_native

@ MartinBüttner - Все 3 лінії мають кінцеві прогалини, хоча я зрозумів , що я можу виправити першу і третю рядки легко шляхом перетворення кінцевий символ в цих рядках від xдо #. Але другий рядок все ще має пробіли у всіх випадках. Бо Aпростір виходить за межі фіналу #інших рядків (що, я думаю, технічно дозволено). Але для I1, I2і т.д. випадків, є ще простір, про який потрібно подбати. Я думаю, що я можу відіграти ще пару персонажів.
gone_native

@gone_native о, ти маєш рацію.
Мартін Ендер

9

Пітон, 168 символів

t=raw_input()*2
Q="G   G  # # # 2 2 H # #\n=====  # # # 2 2 H H H\nG   G  # # H 2 2 H # #"
for A,B,N in('G0A','H0D','212'):Q=Q.replace(A,' #'[t[int(B)]in'I'+N])
print Q

Новим є підхід. У мене є рядок:

G   G  # # # 2 2 H # #
=====  # # # 2 2 H H H
G   G  # # H 2 2 H # #

Я замінити G, Hі 2на основі вхідних даних.


5

J, 153 121 119 символів

Укорочений
('='(;/1,.i.5)}"_1' #'{~5 3 22$#:128#.32x-~3 u:'dt*`J%Q5"xjuH%Jv2uJ!H5 t*`J%@5Jp*uH%Jv2p*!H dp"')echo@{~I1`I2`D1`D2 i.<

Третій підхід: спакувати всіх  #' s у величезне ціле число у вигляді бітів. Додайте =пізніше. Однак симетричність багатьох варіантів роз'ємів все ще не використовується.

Немініфікований
n =. 128 #. 32x -~ 3 u: 'dt*`J%Q5"xjuH%Jv2uJ!H5 t*`J%@5Jp*uH%Jv2p*!H dp"'
f =. ('=' (;/1,.i.5)}"_1 ' #' {~ 5 3 22 $ #: n) echo@{~ I1`I2`D1`D2 i. <

Укорочений (153)
[:echo@>({&(' #=',LF)&.:>;._2#;._1#:96#.32x-~3 u:' (0%dziqrDwbh5Ds6[gEl)_xkBS6?61m$1ne/v(]!&yW?_{K.S^X#Yn_d%O71KqXEw=I;meH>@eG2|2/gcR0'){~D1`D2`I1`I2 i.<

Також як функція. У цьому використовується двійкове кодування змінної довжини шляхом підрахунку їх у двійкові та розділення нулями. 0 в ряд означає  , 1 означає #, 2 означає =, 3 означає новий рядок і 4 відокремлюють п'ять рядків один від одного.

Безумовно
s =. ' (0%dziqrDwbh5Ds6[gEl)_xkBS6?61m$1ne/v(]!&yW?_{K.S^X#Yn_d%O71KqXEw=I;meH>@eG2|2/gcR0'
f =. [: echo@> ({&(' #=',LF)&.:>;._2 #;._1 #: 96 #. 32x -~ 3 u:s) {~ D1`D2`I1`I2 i. <

4

Marbelous, 281 байт / символів

Мінімізовано:

00
]]
GG]]
IIJJJJ
:G
}0
++
>>
>X{0
/\{<{>
:H
}0
-Z
>E-2
-C//
{0
:I
23232003002023}023
LLMMMMNNRROOMMRRLL
0003
0300
NNNN
:J
}0}1
HH-2
KKKK
:K
}1}0
}1}0}0
PPPPQQ
:L
}020
}0202020
:M
20}020}020}0
:N
}0
}020
+W20
:O
3D3D3D3D3D}0
:P
}023}1230A
LLMMNNMM
:Q
2023}0230A
OOMMNNMM
:R
}0
\/0A

Це відбувається D1, D2, I1, I2абоA з STDIN. Обмеження нових рядків для введення необов’язково. Вихід - STDOUT.

Ця програма називає дошки, які друкують частини роз'ємів, або заповнюючи їх # s, або залишаючи пробіли залежно від входів.

Спробуйте цю відповідь тут ; потрібні циліндричні дошки.

з коментарями:

00 .. ..
]] .. .. # get A/D/I
Gt ]] .. # pass into Gt; call PA if A or PrDI if D/I
PA Pr DI

# If 'A' is passed, a marble is emitted down
# Otherwise, marbles are sent left/right
# The value of the marble outputted is (I+1)/2, which creates a difference of 3
#   between D and I, the difference between a space and a #
:Gt
}0 .. ..
++ .. ..
>> .. ..
>X {0 ..
/\ {< {>

# Returns 0 if '1' is passed, and 3 if '2' is passed
:Ff
}0 ..
-Z ..
>E -2
-C //
{0 ..

# Prints connector A 
# Calls made: P1(23) P2(23) P2(20) P3(03) LF(00) P4(20) P2(23) LF(}0) P1(23)
#   P3(03) P3(00) P3(00) P3(03)
:PA
23 23 20 03 00 20 23 }0 23
P1 P2 P2 P3 LF P4 P2 LF P1
00 03 .. .. .. .. .. .. ..
03 00 .. .. .. .. .. .. ..
P3 P3 .. .. .. .. .. .. ..

# Prints connectors D0/D1/I0/I1
# }0 is either '1' or '2'
# }1 is either 32 or 35 (for D or I)
:PrDI
}0 }1
Ff -2
Li DI

# Helper for PrDI
# Calls made: L1(}1, }0) L2(}0) L1(}1, }0)
:LiDI
}1 }0 ..
}1 }0 }0
L1 L1 L2

# Prints '#   # ' (}0 = 0x23) or '      ' (}0 = 0x20)
:P1
}0 20 .. ..
}0 20 20 20

# Prints ' # # #' (}0 = 0x23) or '      ' (}0 = 0x20)
:P2
20 }0 20 }0 20 }0

# Prints ' # #' (}0 = 0x03) or '    ' (}0 = 0x00)
:P3
}0 ..
}0 20
+W 20

# Prints '===== ', }0 must be 0x20
:P4
3D 3D 3D 3D 3D }0

# Prints the top/bottom line of D/I connectors + newline
# Calls made: P1(}0) P2(23) P3(}1) P2(23) 
:L1
}0 23 }1 23 0A
P1 P2 P3 P2 ..

# Prints the middle line of D/I connectors + newline
# Calls made: P4(20) P2(23) P3(}0) P2(23)
:L2
20 23 }0 23 0A
P4 P2 P3 P2 ..

# Emits a newline (0x0A) regardless of input
:LF
}0 ..
\/ 0A

4

Perl 5: 105 (включаючи 1 прапор)

Ще одне рішення Perl. Використовує stdin для параметра.

#!perl -p
@x=map$_?'#':$",!/D/,-/2/,!/A/,1,0;$_='040 33311233
=====433311222
040 33211233';s/\d/$x[$&] /g;s/ $//mg

4

GNU sed, 116 байт

s/.*/&:#   #  33322433\n=====  33322444\n#   #  33422433/
/A/s/[42]/  /g
/1/s/2/  /g
/D/s/#/ /g
s/[2-4]/ #/g
s/.*://

Вихід:

$ echo "A
D1
D2
I1
I2"|sed -f dvi.sed
#   #   # # #       # #
=====   # # #          
#   #   # #         # #
        # # #     # # #
=====   # # #     # # #
        # # #     # # #
        # # # # # # # #
=====   # # # # # # # #
        # # # # # # # #
#   #   # # #     # # #
=====   # # #     # # #
#   #   # # #     # # #
#   #   # # # # # # # #
=====   # # # # # # # #
#   #   # # # # # # # #
$ 

3

J, 198 194 157 символів

Укорочений
3 22 echo@$'x   x  # # # x x x # #=====  # # # x x x x xx   x  # # x x x x # #'('x'I.@:=])}~(5 16$(#' #'$~#)"."0'4123212128262126290901824'){~D1`D2`I1`I2 i.<

Реалізується як функція. Зауважте, що функція - це потяг, тобто потрібно оточити її дужками або призначити ім'я для того, щоб використовувати її (можливо, я повинен вважати парени частиною функції, навіть якщо технічно вони не є).

Безумовно
S1 =. (#' #'$~#)"."0'4123212128262126290901824'
S2 =. 'x   x  # # # x x x # #=====  # # # x x x x xx   x  # # x x x x # #'
f  =. 3 22 echo@$ S2 ('x'I.@:=])}~ (5 16$S1) {~ D1`D2`I1`I2 i. <

Ідея полягає в тому, щоб зберігати загальну частину рядка окремо від символів, які відрізняються між типами з'єднувачів. S1зберігає унікальні символи та S2виступає в якості зразка x, який виконує функції заповнювачів.


3

Пітон - 167 166 164 161 159

C=raw_input()
a=["#   # "," "*6]["D"in C]
r=" #"
b="A"in C
i=3-b
d=(r*[i,5][C[1:]>"1"]).rjust(10)
t=r*3
print a+t+d+"\n===== "+t+d*~-len(C)+"\n"+a+r*i+"  "*b+d

3

JavaScript (ES6) 178 186

Редагування Маючи 7 базових блоків, використовуйте базову 7
Прямий спосіб, використовуючи побудову рядків із заміною та 7 будівельних блоків.
Вихід у stdout, використовуючи попередження за запитом ОП.
Зараз я спробую кілька мікрооптимізацій ...

F=t=>alert(
  {A:21349062249,D1:538695058296,D2:534740169498,I1:151139015296,I2:147184126498}[t]
  .toString(7).replace(/./g,c=>'\n0#   # 0===== 0 # # #0 # #0      0    '.split(0)[c])
)

Тест в консолі FireFox / FireBug - видалення "попередження" для спрощення тесту

;['A','D1','D2','I1','I2'].forEach(i=>console.log(F(i)))

Вихід

#   #  # # #       # #
=====  # # #
#   #  # #         # #

       # # #     # # #
=====  # # #     # # #
       # # #     # # #

       # # # # # # # #
=====  # # # # # # # #
       # # # # # # # #

#   #  # # #     # # #
=====  # # #     # # #
#   #  # # #     # # #

#   #  # # # # # # # #
=====  # # # # # # # #
#   #  # # # # # # # #

2

APL (115)

V←3 22⍴''⋄V[2;⍳5]←'='⋄V[⍳3;(2=⍴I)/(6+2×⍳8)~14 16/⍨'1'∊I]←V[⍳2;12]←V[⍳3;8 10]←V[R/1 3;1 5 20 22/⍨R←∨/'AI'∊I←⍞]←'#'⋄V

Тест:

      V←3 22⍴''⋄V[2;⍳5]←'='⋄V[⍳3;(2=⍴I)/(6+2×⍳8)~14 16/⍨'1'∊I]←V[⍳2;12]←V[⍳3;8 10]←V[R/1 3;1 5 20 22/⍨R←∨/'AI'∊I←⍞]←'#'⋄V
A
#   #  # # #       # #
=====  # # #          
#   #  # #         # #
      V←3 22⍴''⋄V[2;⍳5]←'='⋄V[⍳3;(2=⍴I)/(6+2×⍳8)~14 16/⍨'1'∊I]←V[⍳2;12]←V[⍳3;8 10]←V[R/1 3;1 5 20 22/⍨R←∨/'AI'∊I←⍞]←'#'⋄V
D1
       # # #     # # #
=====  # # #     # # #
       # # #     # # #
      V←3 22⍴''⋄V[2;⍳5]←'='⋄V[⍳3;(2=⍴I)/(6+2×⍳8)~14 16/⍨'1'∊I]←V[⍳2;12]←V[⍳3;8 10]←V[R/1 3;1 5 20 22/⍨R←∨/'AI'∊I←⍞]←'#'⋄V
D2
       # # # # # # # #
=====  # # # # # # # #
       # # # # # # # #
      V←3 22⍴''⋄V[2;⍳5]←'='⋄V[⍳3;(2=⍴I)/(6+2×⍳8)~14 16/⍨'1'∊I]←V[⍳2;12]←V[⍳3;8 10]←V[R/1 3;1 5 20 22/⍨R←∨/'AI'∊I←⍞]←'#'⋄V
I1
#   #  # # #     # # #
=====  # # #     # # #
#   #  # # #     # # #
      V←3 22⍴''⋄V[2;⍳5]←'='⋄V[⍳3;(2=⍴I)/(6+2×⍳8)~14 16/⍨'1'∊I]←V[⍳2;12]←V[⍳3;8 10]←V[R/1 3;1 5 20 22/⍨R←∨/'AI'∊I←⍞]←'#'⋄V
I2
#   #  # # # # # # # #
=====  # # # # # # # #
#   #  # # # # # # # #

@ MartinBüttner: whoops, fix
marinus

2

JavScript ES6, 186 байт

f=c=>(b=(c[0]=='D'?'      ':'#   # '))+(e=(g=r=>parseInt(r,36).toString(2).replace(/./g,n=>' '+[' ','#'][n]))((o=c[1])?(o-1?73:'6f'):'6b'))+'\n===== '+(o?e:' # # #')+'\n'+b+(o?e:g('5f'))

Код швидкий і брудний, але він робить роботу. Здебільшого, #пробіли та пробіли складаються у двійкові, а потім у базу 36. Я шукаю більш елегантне та, сподіваюся, коротше рішення.


Коли я натискаю фрагмент «Запустити код», я нічого не бачу.
AL

Це, мабуть, тому, що він використовує функції стрілок ECMAScript 6, які підтримуються лише в останніх версіях Firefox.
NinjaBearMonkey

Я тестував останню версію Firefox і нічого не відбувається. Чи потрібно щось зробити для перевірки цієї функції?
AL

1
О, це, адже це лише функція. Я додам спосіб її перевірити.
NinjaBearMonkey

ви можете відредагувати код, щоб зробити його доступним як фрагмент (використовуйте другий блок коду для збереження вихідного коду) або видалити фрагмент візуалізації.
AL

1

Perl 5 - 150 (149 + 1 для n )

Гольф:

@b=split//;$_='0   0 ###112##
===== ###11222
0   0 ##2112##';
@c=(@b[0]eq D,@b[1]ne 2,@b[0]eq A);@d=('#',$");s/([#12])/ \1/g;s/(\d)/$d[$c[$1]]/ge;say

Вхід з STDIN, вихід на STDOUT. Працює, виконуючи заповнення певних символів# або введенням залежно від нього.

Безголівки:

@b=split//; # char array from input
$_='0   0 ###112##
===== ###11222
0   0 ##2112##';

@c=(@b[0] eq 'D',@b[1] ne '2',@b[0] eq 'A');
@d=('#',' ');

s/([#12])/ \1/g; # add spaces
s/(\d)/$d[$c[$1]]/ge; # replace numbers with appropriate character
say $_;
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.