s←⊢⊆⍨' '≠⊢
a b c←2097144 131064 1957895
f←{(⊂⍵)∊(12↑v),(s'yi ya ye yao you yan yang yin ying yong yu yue yuan yun wu wa wo wai wei wan wang wen weng nv lv nve lve'),(,⊤(a-8)1966080 393208 1966064 2096720 1966072 1048568a a 2056184a 131048a 7288b 7280 106488b 7280b 0 1958911 73735c c 352263c 24583 1859591c,5⍴7)/,('bpmfdtnlgkhzcs',s'zh ch sh r j q x')∘.,v←'aoe',s'ai ei ao ou an ang en eng ong u ua uo uai ui uan uang un ueng i ia ie iao iu ian iang in ing iong u ue uan un'}
オンラインでお試しください!
進行中のゴルフ。
非ゴルフ
s←{⍵⊆⍨' '≠⍵}
con←s'b p m f d t n l g k h z c s zh ch sh r j q x'
vwl←s'a o e ai ei ao ou an ang en eng ong u ua uo uai ui uan uang un ueng i ia ie iao iu ian iang in ing iong u ue uan un'
tab←con∘.,vwl
bin←,⊤2097136 1966080 393208 1966064 2096720 1966072 1048568 2097144 2097144 2056184 2097144 131048 2097144 7288 131064 7280 106488 131064 7280 131064 0 1958911 73735 1957895 1957895 352263 1957895 24583 1859591 1957895 7 7 7 7 7
all←'aoe',(12↑vwl),(s'yi ya ye yao you yan yang yin ying yong yu yue yuan yun wu wa wo wai wei wan wang wen weng nv lv nve lve'),bin/,tab
f←{(⊂⍵)∊all}
オンラインでお試しください!
ヘルパー関数はs、スペースで区切られた文字列を展開します。
{⍵⊆⍨' '≠⍵} monadic function taking a string
' '≠⍵ 0s at spaces, 1s elsewhere
⍵⊆⍨ Partition (split at 0s)
最初に可能性のある最初と最後の文字列を音節に保存してから、テーブルを作成します tabから、最初のリストの各文字列と2番目のリストの各文字列を連結しを。
次に、バイナリデータを整数のリストとして保存します。一部の整数は繰り返されるため、変数に格納できます。これにより、一部のスペースを削除することもできます。
各整数はバイナリにデコードされ、テーブルの1行を表します。番号の各ビットは、その行の特定の音節が有効な音節であるかどうかを表し、MSBは最初の列を表します。無効な音節はすべてテーブルから削除されます。
テーブルをフラットにしてリストにし、特殊なケースとして最初の子音のないフォームを追加し、最後に入力がリストにあるかどうかを確認します。
さらなるゴルフの可能性の可能性:
- base64またはbase255エンコーディングを書く
- 列と行を並べ替えて、数字を小さくします。
Pythonの便利なスクリプトとテストケースジェネレーター:オンラインで試してみてください!
narどうですか?:P