Piramida Anda
Piramida yang saya ingin Anda bangun seluruhnya terbuat dari kubus. Ini memiliki 24 lapisan, dan lapisan ke- N dari atas berisi N 2 kubus disusun dalam bujur sangkar oleh N. Piramida terlihat seperti ini:
Untuk membangun piramida, Anda akan membutuhkan pasokan kubus. Anda diberi 4.900 kubus disusun dalam 70 oleh 70 persegi yang terlihat seperti ini:
(Oke, saya akui bahwa gambar alun-alun sama sekali tidak perlu.)
Karena 1 2 + 2 2 + 3 2 + ... + 24 2 = 70 2 , Anda memiliki jumlah kubus yang tepat untuk membangun piramida. Yang harus Anda lakukan adalah memberi tahu saya di mana setiap kubus harus pergi.
Tugas Anda
Anda harus memilih bijih acak antara kubus di alun-alun dan kubus di piramida. (Akan lebih baik jika jawaban Anda mengatakan yang mana dari 4900! Biopsi berbeda yang Anda gunakan.)
Kemudian, tulis fungsi atau program yang melakukan hal berikut:
- Mengingat lokasi kubus di 70 dengan 70 persegi (sebagai pasangan koordinat
(X,Y)
), - Keluarkan lokasinya di piramida (sebagai tiga koordinat
(A,B,C)
).
Koordinat input dan output semuanya bisa 0-diindeks atau 1-diindeks. Dengan asumsi 1-diindeks, input Anda (X,Y)
akan menjadi sepasang bilangan bulat antara 1 dan 70. Output Anda (A,B,C)
akan menjadi tiga kali lipat dari bilangan bulat; A
harus menjadi penghitungan lapisan dari atas (antara 1 dan 24) dan (B,C)
harus menjadi koordinat kubus itu di dalam lapisan itu (antara 1 dan A
).
Sebagai contoh:
- kubus atas dari piramida memiliki koordinat
(1,1,1)
. - Empat sudut dasar piramida memiliki koordinat
(24,1,1)
,(24,1,24)
,(24,24,1)
, dan(24,24,24)
. - Jika Anda memutuskan untuk menempatkan sudut-sudut alun-alun di sudut-sudut piramida, maka pada input
(70,1)
Anda dapat memberikan output(24,24,1)
.
Anda mungkin menganggap Anda hanya akan diberikan koordinat yang valid (X,Y)
sebagai input. Kebenaran sepenuhnya ditentukan oleh aturan berikut: dua input valid berbeda harus selalu memberikan dua onput yang valid berbeda.
Ini adalah kode-golf : kode terpendek menang.
sumber
PHP,
75 8278 byteDiindeks 0 :
atur P = X * 70 + Y lalu kurangi P sebesar A 2 sambil berjalan ke lapisan yang benar. A-1; P / A; P% A - selesai.
(terbalik: sambil menambah A ke lapisan yang benar: P = P + A 2 lalu P = P + A * B + C -> X = P / 70, Y = P% 70)
Jalankan dengan
php -nr '<code>' <X> <Y>
; mencetak A_B_C.1-diindeks, 82 byte :
sumber
Python,
807372 bytePengajuan pertama, jangan terlalu keras q:
Diindeks 0
Membuat daftar panjang 4900 dengan semua koordinat piramida dan mengembalikan entri daftar yang berbeda untuk setiap input.
Cobalah online!
sumber
a**2
untuka*a
menyimpan byte.Python 2 , 64 byte
Cobalah online!
sumber
C
89,87,82, 71 byteMengambil solusi Python xnor, dan menghapus linebreak
Diindeks 0
1-diindeks
sumber
Batch, 103 byte
Diindeks 0. Bekerja melalui setiap lapisan mulai dari atas.
sumber
J, 37 byte
-4 byte terima kasih kepada FrownyFrog
Terjemahan yang cukup mudah dari metode Jelly ke pengindeksan J. Menggunakan 0. Kotak piramida atas adalah yang pertama. Sudut kanan bawah pangkalan adalah yang terakhir.
Mayoritas kode adalah boilerplate untuk menghasilkan daftar tiga indeks sebagai konstanta. Menemukan elemen yang benar dalam daftar itu berdasarkan input 2 elemen hanyalah masalah menerjemahkan dari basis 70 dengan
70&#.
Cobalah online!
sumber
(#~~:&a:)
->a:-.~
Sekam , 13 byte
Cobalah online! Indeks mulai dari 1.
Penjelasan
Seperti beberapa jawaban lain, saya membuat daftar lengkap koordinat piramida dan cukup mengindeksnya. Saya melakukan ini dengan mendaftar semua tiga kali lipat di
[A,B,C]
mana angkanya antara 1 dan 24 (dinyatakan sebagai 4! Untuk menyimpan byte) dan menyimpannyaA >= max(B,C)
.sumber