質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

1回答

509閲覧

5×5将棋 MagicBitboard マジックナンバーの考え方求め方

_Victorique__

総合スコア1392

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

2クリップ

投稿2017/08/31 07:42

###前提・実現したいこと
55将棋においてMagicBitboardの実装をしようとしているのですが、マジックナンバーの考え方や求め方で詰まっております。

変数型はint32bit(マスが25マスな為)
bitboardは以下のようであるとします。

C++

1// 0| 1| 2| 3| 4| 2// 5| 6| 7| 8| 9| 3// 10| 11| 12| 13| 14| 4// 15| 16| 17| 18| 19| 5// 20| 21| 22| 23| 24|

例えばですが、角が以下の位置にいる場合、

C++

1// ーーーーー 2// ーーーーー 3// ーー角ーー 4// ーーーーー 5// ーーーーー

利きは以下のようになりますが、

C++

1// ◯ーーー◯ 2// ー◯ー◯ー 3// ーーーーー 4// ー◯ー◯ー 5// ◯ーーー◯

欲しいそれぞれの◯をマジックナンバーをかけることで一つに集めて以下のようにしたいです。

C++

1//上位ビットに集める 2// ーーーーー 3// ーーーーー 4// ーーーーー 5// ーー◯◯◯ 6// ◯◯◯◯◯

仮にも乱数を使って求めることはできました。しかし、どれがどこのbitか分からない上に、角の利きを一つ消してどこがどのbitか確かめようと同じマジックナンバーをかけると集めたbitが散らばってしまいます。考え方がまず間違っているのかも知れません。どなたかご教授いただけませんか?

C++

1#include <string> 2#include <iostream> 3#include <random> 4#include <bitset> 5using namespace std; 6 7int magicNumber(){ 8 random_device rnd; 9 mt19937 mt(rnd()); 10 return mt(); 11} 12 13bool isSatisfy(int num){ 14 int partbit = num >> 23; 15 cout << static_cast<bitset<32>>(num) << " " << static_cast<bitset<32>>(0b11111111) << endl; 16 if(partbit == 0b11111111)return true; 17 else return false; 18} 19 20int main(){ 21 while(true) { 22 int num = 0b11111111; 23 int magicNum = magicNumber(); 24 if(isSatisfy(num*magicNum)){ 25 cout << magicNum << endl; 26 cout << static_cast<bitset<32>>(magicNum) << endl; 27 break; 28 } 29 } 30 return 0; 31}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

MagicNumberの求め方についてですが、isSatisfied関数で、角の利きの範囲の駒の有無の全パターンで正しくビットが集められるかチェックしないといけないのではないでしょうか。

例えば、ここに角がいる場合、

C#

1// ーーーーー 2// ーーーーー 3// ーー角ーー 4// ーーーーー 5// ーーーーー

このパターンだけ計算が合うMagicNumberでは駄目で、

C#

1// ◯ーーー◯ 2// ー◯ー◯ー 3// ーーーーー 4// ー◯ー◯ー 5// ◯ーーー◯

左上の駒がない

C#

1// ーーーー◯ 2// ー◯ー◯ー 3// ーーーーー 4// ー◯ー◯ー 5// ◯ーーー◯

色々ない

C#

1// ◯ーーーー 2// ーーー◯ー 3// ーーーーー 4// ー◯ーーー 5// ◯ーーー◯

全部ない

C#

1// ーーーーー 2// ーーーーー 3// ーーーーー 4// ーーーーー 5// ーーーーー

...など全ての場合をチェックすれば、求められると思います(わかりづらくてすいません)。

投稿2018/01/13 09:59

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

_Victorique__

2018/01/19 09:05

遅くなりましたがそのようですね。マジックナンバーを見つけることができました。ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問