Diberikan dua bilangan bulat positif X dan Y, output setiap kombinasi dari tiga hewan seni ASCII berikut sedemikian rupa sehingga outputnya mengandung tepat X koma ( ,
) dan periode Y ( .
), jika memungkinkan.
Koala: 1 koma, 2 periode
<.,.>
Kepiting: 2 koma, 2 periode
,<..>,
Commapillar: 3 atau lebih koma, 1 periode
<,,,.>
atau
<,,,,.>
atau<,,,,,.>
atau<,,,,,,.>
atau<,,,,,,,.>
dll
Jika tidak ada kombinasi dari hewan-hewan ini yang dapat menghasilkan koma X dan periode Y secara tepat, hasilkan satu commaleon yang akan menyamarkan kegagalan:
~<.,,>~~
Hewan yang dihasilkan dapat dalam jumlah dan urutan apa pun. Mereka mungkin berada dalam string, spasi atau baris baru yang terpisah, atau dalam daftar di mana setiap hewan adalah satu elemen.
Misalnya, untuk X = 7, Y = 5, ini semua akan menjadi output yang valid (dipisahkan oleh baris kosong):
<.,.> <.,.> <,,,,,.>
<.,.>
<,,,,,.>
<.,.>
,<..>, <.,.> <,,,,.>
<,,,,.>
,<..>,
<.,.>
,<..>, <,,,.> ,<..>,
[",<..>,", ",<..>,", "<,,,.>"] (list syntax depends on language)
Perhatikan bahwa (setidaknya dalam contoh ini) ada beberapa set hewan yang dapat bekerja. Tapi ingat Anda hanya perlu mengeluarkan satu solusi yang valid, jika ada. Jumlah hewan atau jumlah hewan yang berbeda tidak masalah.
Untuk input seperti X = 3, Y = 3 atau X = 1, Y = 5 di mana tidak ada solusi, output akan selalu
~<.,,>~~
mungkin dalam daftar elemen tunggal.
Kode terpendek dalam byte menang.
sumber
__int128
dan saya terlalu malas untuk menggunakan perpustakaan bignum. Inilah dump CSV: pastebin.com/ght5xkRu baris dan kolom pertama adalah nilai X dan YJawaban:
Ruby, 139 byte
Fungsi Lambda, mengambil x dan y sebagai argumen dan mengembalikan sebuah string
Jika ada solusi, itu bisa dilakukan dengan semua koala + commapillars atau semua kepiting koala +.
Prinsipnya adalah menggunakan minimum commapillars. Jika angkanya ganjil, kami menggunakan 1 commapillar. bahkan jika kita menggunakan 0 commapillars, kecuali ada lebih banyak koma daripada periode, dalam hal ini kita menggunakan 2.
Jumlah periode yang digunakan dalam noncommapillars (kepiting + koala) harus genap, dan jumlah noncommapillars adalah setengah
(number of periods)-(number of commapillars)
. Jika tidak ada koma yang cukup untuk semua koala, atau terlalu banyak untuk semua kepiting, tidak ada solusi yang mungkin. Kalau tidak, kami kembalikan solusi.Berkomentar dalam program uji
menggunakan "gagal" bukan bunglon untuk kejelasan
Keluaran
sumber
Befunge,
249218 byteCobalah online!
Ini sekarang didasarkan pada algoritma dalam jawaban Ruby oleh Level River St , yang memberikan ruang lingkup yang lebih besar untuk bermain golf dan pengurangan ukuran yang signifikan dibandingkan dengan solusi asli saya.
sumber
C # 6,
321303 bytePanggil
F()
. Dua fungsi lainnya adalah pembantu. demo repl.itsumber