Biarkan papan catur 8x8 diwakili oleh dua nilai berbeda, dengan satu nilai menjadi kotak kosong dan yang lainnya menjadi ratu. Dalam contoh berikut, saya menggunakan 0s sebagai kotak kosong dan 1s sebagai ratu. Sebagai contoh:
diberikan oleh
1 0 1 1 1 0 0 0
1 0 1 0 1 0 1 1
1 0 1 0 1 1 0 1
0 1 0 1 0 1 0 0
0 1 1 0 0 1 0 1
1 0 0 0 1 0 0 0
0 1 0 0 0 1 1 1
0 1 1 1 0 1 0 1
Pertimbangkan jumlah pasangan ratu yang menyerang masing-masing yang setidaknya berjarak satu kuadrat (sebagai pengingat, ratu menyerang secara ortogonal dan diagonal). Dalam contoh di atas, diagram jelek luar biasa berikut ini menunjukkan semua pasangan ini sebagai panah.
Ada 43 pasangan yang ditemukan di atas yang memberikan test case berikut:
Input:
1 0 1 1 1 0 0 0
1 0 1 0 1 0 1 1
1 0 1 0 1 1 0 1
0 1 0 1 0 1 0 0
0 1 1 0 0 1 0 1
1 0 0 0 1 0 0 0
0 1 0 0 0 1 1 1
0 1 1 1 0 1 0 1
Output: 43
Tantangan
Tulis sebuah program yang, diberi status papan yang diwakili oleh dua nilai berbeda, menampilkan jumlah pasangan ratu yang saling serang dengan setidaknya satu kotak di antaranya.
- Anda dapat memasukkan dalam format apa pun yang paling nyaman yang menggunakan dua nilai untuk mewakili kotak kosong dan ratu, misalnya, string 64 "." S untuk kotak kosong dan "Q" untuk queens dengan baris dari bawah ke atas, 8x8 matriks booleans, daftar bilangan bulat 0 dan 1 dll, selama dijelaskan dalam solusi Anda
- Output adalah bilangan bulat
- Metode I / O standar berlaku dan lubang standar dilarang
- Ini kode golf sehingga jawaban tersingkat dalam byte menang
Kasus uji:
Menggunakan format 0 dan 1, dengan 0 kotak kosong dan 1 menjadi ratu:
Input:
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
Output: 0
Input:
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
Output: 0
Input:
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 1 0 0 0 0 1 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0
Output: 1
Input:
0 0 0 0 0 0 0 0
0 0 0 1 0 0 0 0
0 0 0 0 1 0 0 0
0 1 0 0 0 0 1 0
0 0 0 0 1 0 1 0
0 0 0 0 0 0 0 0
0 0 0 1 0 0 1 0
0 0 0 0 0 0 0 0
Output: 10
Input:
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 0 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
Output: 4
Input:
1 1 0 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 0 1 1 1
1 1 1 1 0 1 1 1
1 1 1 1 0 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
1 1 1 1 1 1 1 1
Output: 11