Decode Braille Faux

21
⢣⠃⢎⠆⣇⡇⡯⡂⠈⡏⢰⢵⢐⡭⢸⠪⡀⢸⢐⡭⠀⢹⠁⢎⠆⢸⣱⢸⡃⢎⠰⡱⢸⣱⢸⡃⠈⡏⢸⡃⡱⡁⢹⠁⢸⡀⡇⡗⢅⢸⡃⠈⡏⢸⢼⢸⢐⡭⠀

⣇⢸⡃⢹⠁⢹⠁⣟⢸⢕⢐⡭⠀⡮⡆⡯⡂⣟⠀⡯⠰⡱⢸⣸⢸⢕⠀⣏⡆⢎⠆⢹⠁⣪⠅⢸⢼⢸⠰⣩⢸⢼⠀⡮⡆⡗⢼⢸⣱⠀⢎⠆⡯⠀⢇⠇⡮⡆⡯⡂⡇⡮⡆⣟⡆⣇⢸⡃⠸⡰⡸⢸⢸⣱⠈⡏⢸⢼⠀

⢎⠆⡗⢼⢸⡃⢸⡃⡗⠔⡇⡯⠂⢹⠁⢣⠃⠸⡸⢸⡃⡯⡂⢹⠁⡇⢎⢰⢵⢸⡀⢸⡀⡇⡗⢼⢸⡃⢐⡭⢸⡃⡯⠂⡮⡆⡯⡂⡮⡆⢹⠁⣟⢐⡭⠀⢎⢸⢼⢰⢵⢸⢕⢰⢵⠰⡁⢹⠁⣟⢸⢕⢐⡭⠀

⡮⡆⢐⡭⢸⠕⢰⢵⠰⡁⣟⠀⡇⣪⠅⢈⣝⢸⡃⡯⡂⢎⠆⠸⡰⡸⢸⢸⣱⠈⡏⢸⢼⠀

⣪⠅⢎⠆⢸⠈⡏⠀⣇⠰⡱⠰⡱⢸⠪⡀⣪⠅⢸⡀⡇⡗⢅⢸⡃⠸⡰⡸⠰⡱⢸⢕⢸⣱⢐⡭⠀⡮⡆⡯⡂⣟⠀⣪⠅⣟⢸⠕⢰⢵⢸⢕⢰⢵⠈⡏⢸⡃⣏⡆⢸⣳⠘⡜⠀⢹⠁⢇⢆⠇⢎⠆⢸⡀⡇⡗⢼⢸⡃⣪⠅

⡇⡗⢼⢸⠕⢸⣸⠈⡏⠀⡇⣪⠅⢰⢵⠀⣪⠅⢹⠁⡯⡂⡇⡗⢼⠰⣩⠀⢎⠰⡱⢸⠢⡇⢹⠁⡮⡆⡇⡗⢼⢸⢸⠢⡇⢎⡅⢸⠅⡮⡆⣇⡇⡱⡁⢸⣳⢸⢕⢰⢵⢸⢸⡀⣇⢸⡃⠰⡱⢸⠅

⢎⠆⡗⢼⢸⡀⢣⠃⢸⡃⡗⢼⠰⣩⢸⡀⡇⣪⠅⡧⡇⢸⣸⢸⠕⢸⠕⢸⡃⡯⡂⢎⢰⢵⢐⡭⢸⡃⢸⡀⣟⠈⡏⠈⡏⢸⡃⡯⡂⣪⠅⢰⢵⢸⠢⡇⣏⡆⢐⡭⢸⠕⢰⢵⠰⡁⣟⢐⡭⠀

⡮⡆⣟⡆⢎⢸⣱⢸⡃⡯⠰⣩⢸⢼⢸⢀⠇⡗⢅⢸⡀⡗⠔⡇⡗⢼⠰⡱⢸⠕⠰⣩⡆⡯⡂⣪⠅⢹⠁⣇⡇⢇⠇⢇⢆⠇⡱⡁⢣⠃⣩⡃

⢎⠆⣇⡇⢹⠁⡯⠂⣇⡇⢹⠁⢸⠢⢺⢰⢵⠘⡜⠀⣟⡆⣟⠀⣇⡇⡯⠂⡯⠂⣟⢸⢕⠀⢎⠆⡯⡂⢸⡀⢎⠆⢇⢆⠇⣟⢸⢕⠰⡁⡮⡆⣪⠅⣟⠀

⣪⠅⡧⡇⢎⠆⡯⡂⢹⠁⣟⢐⡭⠈⡏⠀⢇⢆⠇⡇⡗⢼⢐⡭⠀

⡗⢼⠰⡱⠀⣇⠰⡱⠰⡱⢸⠕⢸⢼⠰⡱⢸⡀⣟⢐⡭⠀

Versi ASCII di atas

⡯⡂⣟⢸⡀⡮⡆⢹⠁⣟⢸⣱⠀

Tentang karakter Braille

Karakter Braille mengemas 4 dari 2 persegi panjang titik, yang dapat dilihat sebagai matriks Boolean.

Rangkuman dari semua matriks tersebut adalah matriks boolean 4 x 2 * n, di mana n adalah panjang string input.

Anda harus mencari garis-garis vertikal tanpa titik-titik di dalamnya, dan gunakan itu sebagai pemisah untuk membagi matriks besar menjadi matriks yang lebih kecil untuk setiap karakter.

Kemudian, cari pola untuk mengubahnya menjadi huruf alfabet atau spasi bahasa Inggris. Perhatikan bahwa setelah melepaskan pemisah (garis kosong vertikal), spasi adalah matriks 4 x 0.

Di bawah ini adalah deskripsi alfabet dalam ASCII:

A   | B   | C  | D   | E  | F  | G   | H   | I | J  | K    | L  | M     | N    | O   | P   | Q    | R   | S   | T   | U   | V   | W     | X   | Y   | Z
----+-----+----+-----+----+----+-----+-----+---+----+------+----+-------+------+-----+-----+------+-----+-----+-----+-----+-----+-------+-----+-----+----
.#. | ##. | .# | ##. | ## | ## | .## | #.# | # | .# | #.#. | #. | #...# | #..# | .#. | ##. | .##. | ##. | .## | ### | #.# | #.# | #...# | #.# | #.# | ###
#.# | ### | #. | #.# | ## | #. | #.. | #.# | # | .# | ##.. | #. | ##.## | ##.# | #.# | #.# | #..# | #.# | #.. | .#. | #.# | #.# | #.#.# | .#. | #.# | ..#
### | #.# | #. | #.# | #. | ## | #.# | ### | # | .# | #.#. | #. | #.#.# | #.## | #.# | ##. | #.## | ##. | .## | .#. | #.# | #.# | #.#.# | .#. | .#. | .#.
#.# | ### | .# | ### | ## | #. | .## | #.# | # | #. | #..# | ## | #...# | #..# | .#. | #.. | .### | #.# | ##. | .#. | ### | .#. | .#.#. | #.# | .#. | ###

Spesifikasi

  • Input adalah urutan titik kode Unicode dalam kisaran U + 2800..U + 28FF direpresentasikan sebagai tipe string yang biasa dalam bahasa Anda (mis. Array char, pointer char) dalam setiap pengkodean populer yang didukung (UTF-8, UCS-2 , dll).

  • Ruang tambahan di output baik-baik saja.


Sunting : permintaan maaf kepada mereka yang perambannya salah menentukan titik, seharusnya terlihat seperti ini (gambar): faux-braille

ngn
sumber
5
tugas Anda adalah mendekode teks seperti ini / huruf empat titik tinggi dan lebar variabel / satu garis vertikal kosong memisahkan karakter / spasi nol lebar / jadi sepertinya kata-kata dipisahkan oleh dua baris / input adalah string berisi faux braille dari / hanya huruf besar dan spasi inggris / abcdefghijklmnopqrstuvwxyz / output mungkin huruf besar atau kecil / kemenangan tersingkat / tidak ada celah / terkait
ngn
2
Pola braille
Arnauld

Jawaban:

14

Python 3 , 181 179 171 167 161 159 byte

Input by UTF-16 bit endian kecil tanpa BOM. Pertama, dekomposisi menjadi kolom menggunakan pergeseran bit, dibagi dengan kolom kosong, kemudian hash menjadi tabel pencarian.

-2 byte terima kasih kepada ngn .
-5 byte terima kasih kepada Tn . Xcoder .

lambda h,j=''.join:j(' ZAQV;JWP;MBOS;YRKCGXDF;ILHUENT'[int('0'+i,27)%544%135%32]for i in j(chr(64|i&7|i>>3&8)+chr(64|i>>3&7|i>>4&8)for i in h[::2]).split('@'))

Cobalah online!

Colera Su
sumber
python tidak akan mengeluh jika Anda menghapus ruang antara 39dan if; bahkan lebih pendek jika Anda mengganti if-else dengan and-or trick
ngn
175 byte dengan mengganti i and int(i,27)%15472%39or 0dengan int(i or'0')%15472%39--- Cobalah online!
Tn. Xcoder
Dan 174 byte dengan menetapkan ''.joinke variabel --- Cobalah online!
Tn. Xcoder
11

JavaScript (ES6), 148 146 143 byte

Disimpan 1 byte berkat @ngn

s=>[...s].map(c=>g((k=c.charCodeAt()/8)&8|k*8&7)&g(k&7|k/2&8),o=x='',g=n=>x=n?x*27+n:(o+=' DZQGYWXNHJ.CSTIO.AFB.LPVE..KUMR'[x%854%89%35],n))&&o

Uji kasus

Arnauld
sumber
g((k=c.charCodeAt())&7|k/8&8)&g(k/8&7|k/16&8)->g((k=c.charCodeAt()/8)&8|k*8&7)&g(k&7|k/2&8)
ngn
@ ngn Terima kasih :) Digabung dengan optimasi lain yang tertunda.
Arnauld
Bolehkah saya bertanya, bagaimana Anda menghasilkan yang cemerlang x%854%89%35? Apakah Anda mencoba banyak moduli acak yang berbeda?
ngn
@ ngn Saya sudah mencoba m0 <1000 , m1 <m0 , m2 <m1 (sebenarnya dengan beberapa optimasi lain, tapi itulah idenya). Dan untuk faktor di mana x dikalikan: [4,6,8,9,10,11,12] dan [15 ... 31] . Saat ini mencoba beberapa pendekatan lain.
Arnauld
4

Python 3 , 305 302 301 286 251 198 182 byte

def f(s,A=''):
 for c in s:l=bin(ord(c))[-8:];A+='7'+l[5:]+l[1]+'7'+l[2:5]+l[0]
 print(''.join('K.L.SXC PRU.NYEOGZVJIW..HFBTAQDM'[int('7'+c,22)%141%109%35]for c in A.split('70000')))

Cobalah online!

TFeld
sumber
302 (-3 bytes)
Mr. Xcoder
@ Mr.Xcoder Terima kasih :)
TFeld