Anda diberi banyak bobot, dan tugas Anda adalah membangun ponsel seimbang kecil menggunakan bobot itu.
Input adalah daftar bobot bilangan bulat dalam rentang 1 hingga 9, inklusif. Mungkin ada duplikat.
Outputnya adalah gambar ascii dari sebuah ponsel yang, ketika digantung, akan menyeimbangkan. Mungkin yang terbaik ditunjukkan oleh contoh:
memasukkan
3 8 9 7 5
kemungkinan keluaran
|
+-----+---------+
| |
+--+-+ +----+------+
| | | |
8 ++--+ 7 5
| |
9 3
Anda harus menggunakan karakter ascii seperti yang ditunjukkan. Segmen horisontal dan vertikal dapat memiliki panjang berapa pun. Tidak ada bagian dari ponsel yang dapat menyentuh (horizontal atau vertikal) bagian lain dari ponsel yang tidak terhubung. Semua bobot harus digantung dari segmen vertikal yang panjangnya minimal 1, dan harus ada segmen vertikal tempat seluruh ponsel digantung.
Ukuran mobile adalah jumlah total +
, -
dan |
karakter yang dibutuhkan untuk membangunnya. Ukuran yang lebih rendah lebih baik.
Anda dapat menempatkan sebanyak mungkin koneksi di segmen yang Anda inginkan. Sebagai contoh:
memasukkan
2 3 3 5 3 9
kemungkinan keluaran
|
+---+---+-----------+
| | |
+--+-+ 5 9
| | |
2 | 3
|
+++
| |
3 3
Program pemenang adalah program yang dapat menghasilkan rata-rata ukuran ponsel terendah untuk serangkaian input uji. Tes sebenarnya adalah super rahasia untuk mencegah pengkodean-keras, tetapi akan menjadi sesuatu seperti ini:
8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 7
1 2 3 4 5 6 7 8 9 1 2 3 4 5 6 7 8 9 7 7
3 4 4 4 4 5 5 5 5 6 6 6 6 7 7 7 7
sumber
total_weight_hung_from_point * distance_of_point_from_pivot
harus sama di kedua sisi titik pivot.Jawaban:
Python 2.
Saya
sedikitcurang :Saya hanya membuat ponsel dengan satu horisontal.
Aku punya perasaan (tapi saya belum membuktikannya) bahwa optimal ponsel di bawah kondisi yang diberikan sebenarnya selalu tidak hanya memiliki satu horisontal.Sunting: Tidak selalu benar; dengan2 2 9 1
Nabb telah menemukan contoh balasan dalam komentar di bawah:Saya hanya melakukan tindakan brute-force:
Hasil saya untuk input sampel Anda; masing-masing dijalankan selama 5 detik (saya sadar ini konyol untuk yang kecil - hanya melalui semua permutasi yang mungkin akan lebih cepat). Perhatikan bahwa karena ada elemen acak, proses selanjutnya dapat menemukan hasil yang lebih baik atau lebih buruk.
Kode (verbose, karena ini bukan kode golf):
sumber
1 9 2 8
itu menghasilkan1-------8+-9--2
; dari atas kepala saya, saya tidak dapat menemukan sesuatu yang lebih baik (tapi saya tidak akan bergantung pada itu) - apakah Anda memiliki sesuatu?2 2 9 1
yaitu (2 + 2) * 3 = 9 + 1 * 3 untuk ukuran 16 daripada2-9+--2----1
yang 18. Saya kira ada ambang (mungkin 5 atau 6 ) setelah itu satu baris horisontal selalu optimal.2-2-+9-1
saldo, dengan skor 13(4*2+2*2 = 9*1+1*3)
. Jadi saya tidak berpikir bahwa itu adalah contoh tandingan yang baik.Yah ini adalah pertanyaan lama, tapi saya baru saja melihatnya muncul di tab pertanyaan atas jadi inilah solusi (optimal) saya:
Dari melihat aturan saya cukup yakin itu tidak curang, meskipun rasanya seperti itu. Ini hanya akan menampilkan semua angka yang diberikan dalam rantai vertikal, dengan total biaya 2 * number_of_inputs (yang merupakan jumlah minimum yang mungkin karena setiap angka harus memiliki bilah di atasnya, apa pun tata letaknya). Ini sebuah contoh:
Menghasilkan:
Yang tentu saja dalam keseimbangan sempurna.
Saya awalnya akan mencoba sesuatu yang lebih dalam semangat tantangan ini, tetapi ternyata dengan cepat ia hanya dioptimalkan untuk struktur ini saja.
sumber
|
ke bagian bawah berat.Berikut adalah solusi yang memaksa solusi baris tunggal terkecil. Kode ini mengulangi semua permutasi dan menghitung pusat massa masing-masing. Jika pusat massa memiliki koordinat bilangan bulat, kami telah menemukan solusinya.
Setelah semua permutasi telah dicoba, kami menambahkan segmen ke campuran (setara dengan berat massa 0) di set bobot dan percobaan ulang kami saat ini.
Untuk menjalankan program, lakukan
python balance.py 1 2 2 4
.yang menghasilkan solusi terbaik ini:
sumber
Python 3
Ini tidak lebih buruk dari 1 lebih dari optimal pada salah satu kasus uji, saya percaya, dan melakukannya dalam 5 detik.
Pada dasarnya, saya menggunakan pendekatan bar tunggal. Saya memesan input secara acak, lalu memasukkan bobot ke bilah satu per satu. Setiap elemen diletakkan pada posisi yang meminimalkan kelebihan berat di kedua sisi, atau posisi terbaik kedua dari perspektif itu, menggunakan 75% sebelumnya dan 25% terakhir. Lalu, saya memeriksa apakah ponsel seimbang pada akhirnya, dan lebih baik daripada ponsel terbaik yang ditemukan sejauh ini. Saya menyimpan yang terbaik, kemudian berhenti dan mencetaknya setelah 5 detik pencarian.
Hasil, dalam 5 detik berjalan:
Kode:
Satu-satunya solusi yang saya percaya adalah suboptimal adalah yang terpanjang, yang memiliki solusi ini, yang saya temukan setelah berjalan 10 menit:
sumber