File size: 769 Bytes
079c32c
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
from libc.stdint cimport int32_t
import cython

@cython.boundscheck(False)  # Disable bounds checking for performance
@cython.wraparound(False)   # Disable negative indexing for performance
def legal_actions_cython(int32_t[:, :] board):
    # Use a Python list to store possible legal actions
    cdef list legal_actions = []
    cdef int i, j

    # Iterate over each position on the board
    for i in range(3):
        for j in range(3):
            # If the current position is empty (value is 0), it is a legal action
            if board[i, j] == 0:
                # Add the legal action to the list, representing it as an integer
                legal_actions.append(i * 3 + j)

    # Return the Python list containing all legal actions
    return legal_actions