Шахматное программирование битовой доски на C

У меня проблема с этим фрагментом кода на 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?

По любым вопросам, пожалуйста, добавьте комментарий. Тай: D

0
задан Pioz 9 November 2011 в 21:06
поделиться