Pyth , 106 byte
DhNR.n.e+]++.[\.sllN::.Bk\0\.\1\-\ b*]*\ +2sllNt/16lNNjmj*3\ d.t[h"ET"h"IANM"h"SURWDKGO"h"HVF L PJBXCYZQ
Uji secara online!
Penjelasan
Dalam beberapa kata, apa yang saya lakukan di sini adalah untuk menghasilkan kolom tabel demi kolom dan kemudian memindahkan tabel sebelum mencetaknya. Kami memperhatikan bahwa dalam sebuah kolom, kode morse untuk huruf-huruf tersebut dapat direpresentasikan sebagai string biner (diganti .
dengan 0
dan -
oleh 1
) ketika menghitung dari nol hingga indeks huruf terakhir dalam kolom.
Algoritme bergantung pada fungsi dari mana saya memberikan contoh run di bawah ini (untuk kolom kedua):
1. Takes "IANM" as input
2. Generates the binary representations of zero up to len("IANM"): ["0", "1", "10", "11"]
3. Replace with dots and hyphens: [".", "-", "-.", "--"]
4. Pad with dots up to floor(log2(len("IANM"))): ["..", ".-", "-.", "--"]
5. Add the corresponding letters: [".. I", ".- A", "-. N", "-- M"]
6. After each element, insert a list of 16 / len("IANM") - 1 (= 3) strings containing only spaces of length floor(log2(len("IANM"))) + 2 (= 4):
[".. I", [" ", " ", " "], ".- A", [" ", " ", " "], "-. N", [" ", " ", " "], "-- M", [" ", " ", " "]]
7. Flatten that list:
[".. I", " ", " ", " ", ".- A", " ", " ", " ", "-. N", " ", " ", " ", "-- M", " ", " ", " "]
8. That's it, we have our second column!
Penjelasan kode
Saya memotong kode menjadi dua. Bagian pertama adalah fungsi yang dijelaskan di atas, bagian kedua adalah bagaimana saya menggunakan fungsi:
DhNR.n.e+]++.[\.sllN::.Bk\0\.\1\-\ b*]*\ +2sllNt/16lNN
DhNR # Define a function h taking N returning the rest of the code. N will be a string
.e N # For each character b in N, let k be its index
.Bk # Convert k to binary
: \0\. # Replace zeros with dots (0 -> .)
: \1\- # Replace ones with hyphens (1 -> -)
.[\.sllN # Pad to the left with dots up to floor(log2(len(N))) which is the num of bits required to represent len(N) in binary
++ \ b # Append a space and b
] # Make a list containing only this string. At this point we have something like [". E"] or [".. I"] or ...
+ *]*\ +2sllNt/16lN # (1) Append as many strings of spaces as there are newlines separating each element vertically in the table
.n # At this point the for each is ended. Flatten the resulting list and return it
(1) : Di tabel morse, di kolom pertama, ada tujuh baris setelah setiap baris yang berisi huruf ("E" dan "T"). Di kolom kedua, itu adalah tiga baris. Lalu satu (kolom ketiga), lalu nol (kolom terakhir). Di 16 / n - 1
situlah n
jumlah huruf dalam kolom (yang ada N
dalam kode di atas). Apa yang dilakukan kode pada baris
(1) :
*]*\ +2sllNt/16lN
sllN # Computes the num of bits required to represent len(N) in binary
+2 # To that, add two. We now have the length of a element of the current column
*\ # Make a string of spaces of that length (note the trailing space)
t/16lN # Computes 16 / len(N) - 1
*] # Make a list of that length with the string of spaces (something like [" ", " ", ...])
Baiklah, sekarang kita memiliki fungsi membantu yang bagus h
yang pada dasarnya menghasilkan kolom tabel dari urutan karakter. Mari kita gunakan (perhatikan dua spasi tambahan dalam kode di bawah ini):
jmj*3\ d.t[h"ET"h"IANM"h"SURWDKGO"h"HVF L PJBXCYZQ
h"ET" # Generate the first column
h"IANM" # Generate the second column
h"SURWDKGO" # Generate the third column
h"HVF L PJBXCYZQ # Generate the last column (note the two trailing spaces)
[ # Make a list out of those columns
.t # Transpose, because we can print line by line, but not column by column
mj*3\ d # For each line, join the elements in that line on " " (that is, concatenate the elements of the lines but insert " " between each one)
j # Join all lines on newline
Kode masih dapat disingkat; mungkin saya akan kembali lagi nanti.