CJam, 23 16 byte
Mungkin ada solusi matematika yang elegan untuk masalah ini. Tapi saya tidak tahu bagaimana menemukannya, jadi sangat sulit mengkodekan pengkodean!
Saya menemukan satu! Yah, ini bukan solusi matematis yang elegan karena menggunakan operasi bitwise, tetapi sepenuhnya formula.
li_o1^_p_6|o3+6%
Cobalah online.
Tata letak kubus
4-----7 4-----7 3-----2
/| /| / 0 /| / 3 /|
1-----0 | 1-----0 | 6-----5 |
| | | | | |2| | |4|
| 5---|-2 | 1 | 2 | 5 | 7
|/ |/ | |/ | |/
6-----3 6-----3 1-----4
Penjelasan
Jawaban lama saya sudah meletakkan kubus sedemikian rupa sehingga setiap wajah dapat digambarkan dengan nomor simpul pertama (kiri atas) sama dengan nomor wajah. Tetapi saya ingin dapat menghitung lebih banyak nomor titik menggunakan nomor wajah. Pada titik tertentu, saya muncul dengan ide yang membuat kaki saya di pintu, untuk menghitung nomor simpul kedua (atas-kiri) sebagai nomor wajah XOR 1. Dan setelah beberapa saat coba-coba, saya berhasil muncul dengan tata letak yang ditunjukkan di atas dan rumus di bawah ini yang memungkinkan saya menghitung setiap jumlah titik untuk wajah dengan n
cukup ringkas:
- Kiri atas:
n
- Kanan atas:
n^1
- Kiri bawah:
(n^1)|6
- Kanan bawah:
((n^1)+3)%6
Untuk referensi, saya akan mereproduksi output untuk setiap wajah dalam tata letak yang diinginkan di sini:
Face: 0 1 2 3 4 5
Vertices: 01 10 23 32 45 54
74 63 70 65 72 61
Jadi seluruh program hanya membaca nomor wajah input dan menghasilkan nilai-nilai ini secara berurutan, meskipun dengan logika pencetakan yang sedikit berbeda untuk simpul yang berbeda. Perhatikan bahwa, karena setiap simpul setelah yang pertama dimulai dengan basis n^1
, saya hanya perlu menghitungnya sekali, yang memadatkan logika lebih jauh.
Demi anak cucu, dan karena saya pikir itu masih pendekatan yang cukup bagus, inilah jawaban lama saya.
CJam, 23 byte
Mungkin ada solusi matematika yang elegan untuk masalah ini. Tapi saya tidak tahu bagaimana menemukannya, jadi sangat sulit mengkodekan pengkodean!
"pÜ×ñè¨"487b8b3/ri_o=~p
Cobalah online.
Tata letak kubus
0-----7 0-----7 3-----6
/| /| / 0 /| / 3 /|
1-----2 | 1-----2 | 4-----5 |
| | | | | |2| | |5|
| 5---|-6 | 1 | 6 | 4 | 7
|/ |/ | |/ | |/
4-----3 4-----3 1-----0
Penjelasan
Pendekatan dasar yang digunakan adalah mengkodekan simpul untuk setiap wajah dalam ruang sesedikit mungkin. Sama halnya dengan solusi konversi basis Optimizer, ini memperlakukan daftar simpul sebagai angka oktal yang dikemas sebagai data karakter ASCII. Tapi di situlah kesamaan berakhir untuk memberi jalan bagi optimasi lebih lanjut!
Berikut adalah tiga kunci optimasi yang saya buat untuk solusi "naif":
- Letakkan kubus sedemikian rupa sehingga setiap wajah dapat digambarkan dengan nomor wajahnya sebagai nomor simpul pertama. Melihat tata letak kubus saya seperti yang disajikan di atas, orang dapat melihat bahwa nomor simpul atas-kiri dari setiap wajah sama dengan nomor wajah. Ini memungkinkan saya untuk mengkodekan enam simpul lebih sedikit dengan biaya harus mencetak input kembali, yang ternyata menghemat satu byte.
- Kemas data verteks ke dalam string yang masing-masing "karakter" memiliki maksimum lebih besar dari 256. Karena maksimum ini meningkat melampaui 256, panjang string perlahan-lahan menurun, tetapi semakin besar kemungkinan satu "karakter" melebihi 256 dan dengan demikian tidak lagi bagian dari set karakter ASCII 1-byte. Jadi saya menulis sebuah program yang mencoba menyandikan data titik di setiap basis dari 256 hingga 1000, dengan yang saya temukan sekitar 10 basis yang menyimpan satu byte data karakter dibandingkan dengan basis 256. Saya memilih 487, karena itu juga memiliki properti bagus yang string yang dihasilkan seluruhnya terdiri dari ASCII yang dapat dicetak.
- Dicampur dengan optimasi pertama, menghasilkan output secara asimetris. Pendekatan yang biasa dilakukan di CJam adalah memformat data vertex sebagai daftar 2-elemen dari daftar 2-elemen, menyisipkan baris baru di tengah, dan membiarkan hasilnya dicetak secara implisit. Tapi saya malah mencetak simpul pertama (sama dengan nomor wajah masukan) dengan operator yang tidak menambahkan baris baru, mengambil daftar 3-elemen dari simpul lain, ambil simpul berikutnya dan mencetaknya dengan operator yang menambahkan baris baru, dan biarkan dua simpul lainnya dicetak secara implisit. Ini menghemat satu byte.
6+n%2 --> 6|n
(saya sudah memasukkannya ke dalam jawaban Ruby saya.) Perhatikan bahwa dengan melakukan transformasin --> n^1
pada wajah Anda dapat menyederhanakan rumus Anda, meskipun saya menduga bahwa ketika Anda membuangn
dan melanjutkannya,n^1
ia akan menang. dapat membantu skor Anda.n
dann^1
memasangkan di sekitar kubus akan memungkinkan saya untuk menghitung simpul lain hanya dengan|6
. Dan saya tidak melihatn --> n^1
transformasi itu, yang jelas masuk akal. Tapi Anda menduga dengan benar bahwa itu tidak akan benar-benar mempengaruhi skor saya, jadi saya mungkin akan membiarkannya apa adanya.6+n%2 --> 6|n
) Saya harap Anda tidak keberatan. Saya memang menggunakann --> n^1
transformasi pada wajah, jadi revisi terbaru saya memberikan output yang sama seperti milik Anda, tetapi dengan input yang berbeda. BTW, saya kira operasi bit tidak bagus, itu semua tergantung bagaimana Anda menggunakannya!~.1^..n@6|@3+6%
C, 69
Tidak terkurung dalam program uji
Penjelasan
Penomoran kubus saya, saat dibuka, terlihat seperti ini:
Pojok kiri atas memiliki nomor yang sama dengan wajah.
Pojok kanan bawah memiliki nomor
(n+2)%6
Untuk aneh
n
sudut kanan atas adalah(n+1)%6
dan kiri bawah6
Bahkan
n
sudut kanan atas7
dan kiri bawah(n+1)%6
Program ini menampilkan angka ganjil seperti yang ditunjukkan dan angka genap diputar 180 derajat. Ini berarti sudut kanan atas selalu
(n+1)%6
dan kiri bawah selalu(n+1)%2+6
. Pembalikann
dann+2
lebih mudah (dilakukan dengan mengaturc=n+1
dan menggunakand
untuk menambah atau mengurangi1
atau-1
sesuai kebutuhan.)Keluaran
sumber
c%6
kec%=6
dan berputar wajah sehingga datang pertama, itu harus mungkin untuk menghilangkan beberapa perhitungan modulus.) Hal lain untuk bereksperimen dengan is menggeser pelabelan wajah oleh satu tempat, jadi saya mendapatkann-1,n,n+1
bukann,n+1,n+2
.n
global, sehingga Anda dapat menyimpan beberapa byte dengan mendeklarasikannya lebih tinggi, ubah tanda tangannyaf()
? Atau apakah kita hanya melihatf
fungsinya di sini?"You may write a function instead of a program"
jadi saya hanya menghitung fungsinya. Bagaimanapun, ini hanyalah bukti konsep dalam bahasa yang paling saya kenal. Saya lebih tertarik mempersingkat jawaban Ruby saya, yang sejak awal sudah jauh lebih pendek dari ini.Elemen, 18
Tidak seperti banyak bahasa golf yang lebih maju, Element tidak memiliki operator kompresi, sehingga singkatnya solusi ini terkait erat dengan skema penomoran yang tepat digunakan. Setelah beberapa percobaan, saya telah membuat skema penomoran baru yang memungkinkan simpul untuk dihitung hanya menggunakan operasi aritmatika sederhana.
Sudut kiri atas adalah 6 jika genap dan 7 jika aneh. Pojok kanan atas adalah nomor wajah itu sendiri. Kiri bawah adalah nomor wajah, ditambah 2, mod 6. Kanan bawah adalah 5 minus nomor wajah.
Berikut ini penjelasan kodenya.
Berikut adalah output untuk masing-masing wajah:
sumber
Oktaf,
1081006850 byteTentu saja ada cara melakukannya dengan cara yang lebih elegan dari pendekatan saya sebelumnya, hardcoding biasa. Saya kagum bagaimana Octave jauh lebih cocok untuk codegolf daripada Matlab =)
Tata letak:
(Maaf, saya lupa menambahkan ini.)
Tata letak kubus
Versi lama:
Versi yang lebih lama:
Ini benar-benar akan membuat array 2x2x2 dan kemudian memilih 'slice'. Kami melakukan permutasi matriks 3d dan setiap kali memilih irisan atas atau bawah. (Yang ini tidak bekerja di matlab karena pengindeksan ekspresi daripada matriks) Saya yakin akan ada cara yang lebih langsung untuk melakukannya yang akan lebih pendek.
sumber
CJam,
3128 (atau 26) byteyang juga dapat dikompres menggunakan konversi basis ke versi 26 byte .
Mengasumsikan kubus seperti:
dengan wajah seperti
Cobalah online di sini
sumber
CJam (25 byte)
Ini berisi karakter yang tidak dapat dicetak dan tab (yang akan hancur oleh perangkat lunak StackExchange), sehingga dalam format xxd:
Demo online
Kubus:
Ini murni hard-coding, dengan simpul kubus dipilih untuk memaksimalkan kompresibilitas dasar. Saya mendekodekan ke angka 2 digit, sehingga tidak ada yang bisa mulai dengan 0. Saya juga tidak ingin ada yang memulai dengan 7, karena itu mendorong basis kedua terlalu tinggi. Karena itu 0 dan 7 harus berada di diagonal panjang. Saya ingin 10 edge pergi dulu untuk mengurangi nilai yang saya encoding. Selain itu, ada cukup banyak fleksibilitas tanpa mengubah jumlah byte.
Saya sedikit kecewa karena telah mengeluarkan karakter pertama dari string ajaib, perlu untuk melemparkannya ke int sebelum menggunakannya sebagai basis untuk konversi basis. Semoga versi CJam yang akan datang akan menghemat byte itu, meskipun akan terlambat untuk mengeksploitasinya di sini.
sumber
JavaScript (ES6), 53
62Edit Simpan 8 byte menggunakan string template, thx @NinjaBearMonkey. Hati-hati, baris baru di dalam tanda kutip signifikan dan tidak dapat diciutkan.
Tidak bisa pintar dalam Javascript, terlalu bertele-tele.
Keluaran
for(i=0;i<6;i++)console.log(f(i),i)
Lihat potongan untuk veify asosiasi nomor ( yang menyenangkan)
Tampilkan cuplikan kode
sumber
\n
yang sebenarnya, yang seharusnya menghemat 8 byte.Ruby Rev 1,
4036->(c){print(c^1,c,"\n",6|c,(c+3)%6)}
Terima kasih kepada @rcrmn karena menyarankan menggunakan lambda untuk menghemat 4 byte. Saya tidak yakin tentang meninggalkannya secara anonim tetapi tampaknya telah dibahas pada meta di sini dan memutuskan ini tidak masalah.
Ini dia sebagai fungsi 40-byte, untuk perbandingan dengan jawaban Rev 0 Ruby saya, juga di bawah ini (jawaban C asli ada di pos terpisah.)
Inspirasi lebih lanjut dari Runer112: Ini bergantung pada modifikasi skema penomoran yang digunakan dalam jawaban terbarunya (16 byte!). Port langsung skema PhiNotPi akan memberikan skor yang sama.
Dengan menggeser penomoran dari putaran 0 putaran satu langkah, dan mengambil semuanya XOR 1, kita mendapatkan kubus berikut:
Keluaran
Ruby Rev 0,
56 5250Disimpan 4 byte dengan menghapus yang tidak perlu
()%6
daric-d
dan 2 lainnya (terinspirasi oleh runer112) oleh6+c%2 --> 6|c
.Skor untuk fungsi, yang hanya merupakan baris pertama. Saya baru di Ruby dan saya terkejut saya tidak dapat menemukan cara yang lebih pendek dari 12 karakter (11 ditambah baris baru) untuk mendapatkan nomor input pengguna ke n. Akibatnya, melakukan fungsi alih-alih program menghemat 1 byte.
Ini adalah port jawaban C saya. Dalam C,
%
operator mengembalikan nilai negatif dengan angka negatif. Di Ruby itu selalu mengembalikan nilai positif, jadi tidak perlu menambahkan 1c
. Akibatnya, menguntungkan untuk mengubah penomoran wajah dengan 1 seperti di bawah ini:Dengan penomoran wajah yang baru, program mencetak rata seperti ditunjukkan di atas dan peluang diputar hingga 180 derajat:
sumber
->(x){...code...}
yang membuat definisi fungsi Anda 4 karakter lebih pendek. Anda kemudian harus menugaskannya ke variabel untuk menggunakannya, dan menyebutnya dengan #callf=->(c){print(c^1,c,"\n",6|c,(c+3)%6)}
tidak berjalan dan 2 karakter lebih pendek (4 karakter lebih pendek jika saya menghilangkanf=
). Tidak yakin apakah adil untuk dihilangkanf=
tetapi pertanyaannya tidak mengatakan bahwa fungsinya tidak bisa anonim. Apa yang saya temukan aneh adalah bahwa sintaks ini sama sekali berbeda dari sintaks yang diperlihatkan kepada pemula, yang memiliki parameter yang disahkan di dalam kurung:f=lambda{|c|print(c^1,c,"\n",6|c,(c+3)%6)}
Pyth, 30
Terima kasih @ Jakube untuk 2 byte.
Coba di sini.
Saran bermain golf dari para ahli pyth akan diterima dengan ramah. Secara khusus saya pikir bagian output mungkin memiliki beberapa peningkatan.
Port python berikut: ...
Python, 109
... yang merupakan pelabuhan
Pure Bash, 130
Untuk keperluan penjelasan:
Simpul kubus diberi nomor sebagai berikut:
Dan wajah-wajah diberi nomor sebagai berikut:
The
Swap
kolom menunjukkan urutan simpul harus diaktifkan dalam output.Algoritma dimulai dengan semua simpul {0..7}. Verteks dihilangkan sesuai dengan bit yang diatur dalam angka verteks:
Verteks "disimpan" ditambahkan ke string. String adalah output chars 0,1 kemudian 2,3 atau sebaliknya, tergantung pada apakah flag swap (face number mod 2) diatur.
sumber
J - 26 byte
Berfungsi mengambil nomor muka sebagai argumen dan mengembalikan grid angka.
Kami menggunakan kubus berikut:
Contoh (coba sendiri di tryj.tk ):
Roti dan mentega itu
0&(|:|.)
. Ini adalah kata kerja yang membalik dan memutar kubus sedemikian rupa untuk mengunjungi setiap wajah ketika diterapkan secara iteratif, yang kami lakukan dengan menggunakan argumen input. Vertikal dari kubus dihasilkan olehi.3#2
, jadi kami menggunakannya sebagai titik awal, dan mengambil wajah depan0...{
ketika kita selesai.Mencetak digit sebagai string menghabiskan 8 karakter:
{.@":"0@
Jika kami diizinkan untuk mengembalikan array, itu berarti penghematan 8 karakter secara keseluruhan. [Memulai dengan tangan gemetar dan mencekam tak terlihat]sumber
> <> (Ikan) , 38 byte
Setiap output disimpan sebagai dua baris 2 digit. Baris disimpan sebagai kode dalam string
'/ =/2= 28"H'
(kecuali baris10
yang ditambahkan setelah string sebagaia
). Karakter pertama (/ = 47
) digunakan untuk mengarahkan aliran program pada interaksi kedua.2*(53-n)
Elemen atas dibuang (di mana n adalah kode karakter dari nomor input) dan dua kode berikutnya dicetak dengan baris baru di antaranya.Tata letak:
sumber