ビットカウントとは 整数を二進数表示した時、0と1の組み合わせになります。 例えば、十進数の 21 を2進数表示した場合、 0001 0101 のようになります。 この時、 0001 0101 に含まれる1の数を数えることをビットカウントと言います。 0001 0101 の場合、立っているビット数は 3 ですね。 なんてことなさそうな計算ですが、実は、超高速なアルゴリズムがあります。 今回は、このアルゴリズムに触れ、感動した私がそれを解説してみることにします。 ビットカウントのアルゴリズム チェスや将棋、オセロのようなボードゲームのAIでは、盤面をBitboardというバイナリで表現することが多いです。 例えば、ある列の駒の数を数える場合、その列に対応するビット列を取り出し、立っているビット数を取得する必要があります。 強いAIを作るためには、高速な計算が必要となります。 全体のビット数分
![ビットカウントする高速アルゴリズムをPythonで実装しながら詳しく解説してみる - Qiita](https://cdn-ak-scissors.b.st-hatena.com/image/square/642ec0003746d3a8a2188779a9c1d40ffd343340/height=288;version=1;width=512/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Farticle-ogp-background-9f5428127621718a910c8b63951390ad.png%3Fixlib%3Drb-4.0.0%26w%3D1200%26mark64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZoPTMzNiZ0eHQ9JUUzJTgzJTkzJUUzJTgzJTgzJUUzJTgzJTg4JUUzJTgyJUFCJUUzJTgyJUE2JUUzJTgzJUIzJUUzJTgzJTg4JUUzJTgxJTk5JUUzJTgyJThCJUU5JUFCJTk4JUU5JTgwJTlGJUUzJTgyJUEyJUUzJTgzJUFCJUUzJTgyJUI0JUUzJTgzJUFBJUUzJTgyJUJBJUUzJTgzJUEwJUUzJTgyJTkyUHl0aG9uJUUzJTgxJUE3JUU1JUFFJTlGJUU4JUEzJTg1JUUzJTgxJTk3JUUzJTgxJUFBJUUzJTgxJThDJUUzJTgyJTg5JUU4JUE5JUIzJUUzJTgxJTk3JUUzJTgxJThGJUU4JUE3JUEzJUU4JUFBJUFDJUUzJTgxJTk3JUUzJTgxJUE2JUUzJTgxJUJGJUUzJTgyJThCJnR4dC1jb2xvcj0lMjMyMTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9NTYmdHh0LWNsaXA9ZWxsaXBzaXMmdHh0LWFsaWduPWxlZnQlMkN0b3Amcz1kYWFjMThkNzJmMTAwNjk2NWExMGNjYmM1NTIyODg3Nw%26mark-x%3D142%26mark-y%3D112%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTcxNiZ0eHQ9JTQwemF3YXdhaG9nZSUyMGluJTIwJUU2JUEwJUFBJUU1JUJDJThGJUU0JUJDJTlBJUU3JUE0JUJFJUUzJTgzJThBJUUzJTgzJUFDJUUzJTgzJTgzJUUzJTgyJUI4JUUzJTgzJUFGJUUzJTgzJUJDJUUzJTgyJUFGJnR4dC1jb2xvcj0lMjMyMTIxMjEmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9MzImdHh0LWFsaWduPWxlZnQlMkN0b3Amcz1iZmMyYmRmNjQyYjFiODg4NWY3YmFkYWZjNTM5YmZiMw%26blend-x%3D142%26blend-y%3D491%26blend-mode%3Dnormal%26s%3D7f6f48b943a4578f2f981e761fd84f75)