Ada 21 item di Minecraft yang bisa Anda kerajinan hanya menggunakan kayu dan barang-barang yang dibuat dari kayu:
kapak
perahu
mangkuk
tombol
dada
kerajinan meja
pintu
pagar
gerbang
cangkul
tangga
beliung
papan
pressure plate
sekop
tanda
slab
tangga
menempel
pedang
pintu jebakan
Daftar ini mengasumsikan bahwa 6 jenis papan kayu / lempengan / pintu / dll. semua dihitung sebagai item yang sama. Cara lain untuk memikirkannya adalah dengan menganggap Anda hanya memiliki akses ke satu jenis kayu.
Masing-masing dari 21 item ini memiliki resep kerajinan yang berbeda . Kami akan mewakili masing-masing resep ini sebagai kotak karakter 2 × 2 atau 3 × 3 .WPS
. Ini .
adalah slot kerajinan yang kosong, W
untuk kayu , P
untuk papan kayu , dan S
untuk tongkat . Tidak diperlukan karakter lain untuk item-item khusus ini.
Sebagai contoh, ini adalah resep untuk peti :
PPP
P.P
PPP
Tantangan
Tulis program yang menggunakan salah satu dari 21 item kami, persis seperti yang muncul di atas, dan cetak resep kerajinan yang valid untuk item itu.
Resep kerajinan adalah terjemahan yang tidak berubah-ubah, jadi jika inputnya fence
, keduanya valid:
PSP
PSP
...
...
PSP
PSP
Jika sebuah resep cocok dengan kisi 2 × 2, Anda dapat mengeluarkannya dalam kisi 2 × 2 atau 3 × 3. misalnya stick
:
.P
.P
...
.P.
.P.
Resep juga dapat dicerminkan secara horizontal (di sekitar garis simetri vertikal), meskipun ini hanya membuat perbedaan untuk kapak, cangkul, dan tangga. misalnya hoe
:
.PP
.S.
.S.
PP.
.S.
.S.
Jadi, mengeluarkan resep apa saja yang sesuai dengan kisi dan memiliki bentuk yang benar (mengabaikan terjemahan dan mirroring) adalah apa yang perlu dilakukan oleh program Anda. Ini semua adalah resep yang akan dikenali oleh game resmi. (Perhatikan bahwa resep tidak dapat diputar atau dicerminkan secara vertikal.)
Detail
- Ambil input dari stdin atau baris perintah. Anda dapat menganggap input selalu valid. Membutuhkan kutipan di sekitar input (mis.
"chest"
) Baik-baik saja. - Output ke stdout (atau alternatif terdekat) dengan baris tambahan opsional.
- Pengajuan terpendek dalam byte menang.
Contoh
Berikut daftar semua input dan output sampel:
axe
PP.
SP.
S..
boat
P.P
PPP
...
bowl
P.P
.P.
...
button
P.
..
chest
PPP
P.P
PPP
crafting table
PP
PP
door
PP.
PP.
PP.
fence
PSP
PSP
...
gate
SPS
SPS
...
hoe
PP.
S..
S..
ladder
S.S
SSS
S.S
pickaxe
PPP
.S.
.S.
planks
W.
..
pressure plate
PP
..
shovel
P..
S..
S..
sign
PPP
PPP
.S.
slab
PPP
...
...
stairs
P..
PP.
PPP
stick
P.
P.
sword
P..
P..
S..
trapdoor
PPP
PPP
...
sumber
Jawaban:
CJam,
100969491 byteStackExchange mangles tidak dapat diperbaiki, jadi daripada menyalin dan menempel di sini adalah permalink . Selain itu, inilah program pengujiannya .
(Terima kasih kepada @Optimizer untuk memberi tahu saya tentang
f
dan @ MartinBüttner karena memberi tahu saya tentang pengindeksan modulo CJam.)Cygwin
hexdump
:Penjelasan
Untuk membuat resep, kami menggunakan 13 baris berbeda (juga tercantum penjelasan mengapa ini minimal):
Kami menyandikan baris via
Z"O>HVa=4a"98bZb+"P.SW"f=3/
, yang memberiBit pertama
"+WcbKF AQH;_{GM8Lyf=_tmTn"141bDb3/
mengkodekan resep, memberiPerhatikan bagaimana entri pertama
[3 3 8]
, yang merupakan resep untuksign
.l72b970%=
membaca di input, lalu menerapkan beberapa sihir untuk mengetahui resep yang akan diambil dari daftar. Meskipun kami hanya memiliki 21 resep, ada 24 dalam daftar - beberapa tempat tambahan sesuai dengan[1 0 0]
s.Setelah membaca input, memilih resep dan mengubah resep menjadi baris, kami memasukkan beberapa baris baru
N*
dan cetak otomatis.CJam,
898683 byte... ternyata hardcoding semua output sedikit lebih baik di CJam. Saya cukup kecewa.
Sekali lagi kami memiliki beberapa unsintables jadi inilah permalink dan program pengujian .
Cygwin
hexdump
:Penjelasan
Keluaran dikodekan menggunakan basis 3, dengan satu-satunya
W
ditempelkan ke depan sebelum string dipecah menjadi 3s untuk memberikan baris, dan baris dibagi menjadi kelompok-kelompok 3s untuk memberikan resep.Seperti di atas, sihir konversi dasar dan modulo digunakan untuk memilih resep. Ada 22 resep (satu tidak terpakai) tetapi kita perlu mengambil modulo 24, jadi kita sebenarnya perlu menentukan
24%
waktu ini secara eksplisit daripada mengandalkan pengindeksan modulo.sumber
xxd
? Permalinks tidak berfungsi di Firefox.JavaScript (ES6), 235
241 262Edit Menyalahgunakan bahkan lebih dari aturan bahwa input selalu valid: hanya ada 1 item yang membutuhkan W, dan itu bisa menjadi casing khusus. Jadi grid output dikodekan sebagai 9 digit basis 3 angka.
235 byte dengan I / O via popup.
221 byte sebagai fungsi yang dapat diuji.
Output selalu berupa grid 3x3. Dengan 4 symobols keluaran yang tersedia, kisi tersebut dikodekan sebagai angka bit 3x3x2 (18). Dan sebagai input harus selalu valid, string disimpan terpotong ke minimum.
Uji di Firefox / konsol FireBug
Keluaran
sumber
Python, 305 byte
Penjelasan
Komentar
Kode ini jelas bukan yang terkecil tetapi berfungsi dengan baik. Saya puas. :)
Python, 282 byte
Menggunakan teknik yang sama untuk menghasilkan pengidentifikasi unik tetapi langsung mencari resep dalam array. Ini jauh lebih sederhana dan sedikit lebih kompak daripada kode pertama saya.
sumber
W.\n..