Программирование шахматных досок на С - PullRequest
0 голосов
/ 10 ноября 2011

У меня проблема с этим фрагментом кода на языке C.

#include <stdio.h>
#include <stdint.h>

typedef uint64_t bboard;

// Accessing a square of the bitboard
int
get (bboard b, int square)
{
  return (b & (1ULL << square));
}

void
print_board (bboard b)
{
  int i, j, square;
  for (i = 7; i >= 0; i--) // rank => top to bottom
    {
      for (j = 0; j < 8; j++) // file => left to right
        printf ("%d ", get (b, j+8*i) ? 1 : 0);
      printf ("\n");
    }
}

int
main ()
{
  bboard b = 0xffffffffffffffff;
  print_board (b);
}

// result that I have
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 
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 Ответ

6 голосов
/ 10 ноября 2011

get возвращает int, но (b & (1ULL << square)) является uint64_t. Когда (b & (1ULL << square)) больше INT_MAX, результат не определен; в этом случае он усекается и возвращает 0.

Если get возвращает bboard, это работает как ожидалось (проверено здесь: http://codepad.org/zEZiJKeR).

...