diff options
author | lonkaars <l.leblansch@gmail.com> | 2021-02-17 12:37:03 +0100 |
---|---|---|
committer | lonkaars <l.leblansch@gmail.com> | 2021-02-17 12:37:03 +0100 |
commit | 72d8c0178a8b21a8f0d19da9689a5bac30ccbcbb (patch) | |
tree | 423cd81dd77508bd783a97a89c889b1fbad709b3 /console | |
parent | c45d0923b65c7409dcb18554c3e1dd00324e3f92 (diff) |
beginsels website game dings
Diffstat (limited to 'console')
-rw-r--r-- | console/voerbak.c | 100 | ||||
-rw-r--r-- | console/voerbak_connector.py | 79 |
2 files changed, 0 insertions, 179 deletions
diff --git a/console/voerbak.c b/console/voerbak.c deleted file mode 100644 index f0ecb4a..0000000 --- a/console/voerbak.c +++ /dev/null @@ -1,100 +0,0 @@ -#include <stdio.h> -#include <stdlib.h> -#include <memory.h> -#include <stdbool.h> - -void printBoard(int board[], int width, int height) { - for (int i = 0; i < width * height; i++) - printf("%d", board[i]); - printf("\n"); - fflush(stdout); -} - -int recursiveSolve(int board[], int width, int height, int pos, int checkFor, int direction, int currentLength) { - int overflow = (pos % width) + direction; - if (overflow == width || overflow == -1) - return currentLength; - int newPos = pos + direction; - if (newPos < 0 || newPos > width * height - 1) - return currentLength; - if (board[newPos] != checkFor) - return currentLength; - return recursiveSolve(board, width, height, newPos, checkFor, direction, currentLength + 1); -} - -bool checkWin(int board[], int width, int height, int pos) { - int directions[8] = { - width, // north - width + 1, // northeast - 1, // east - -width + 1, // southeast - -width, // south - -width -1, // southwest - -1, // west - width -1 // northwest - }; - - int values[8]; - for (int i = 0; i < 8; i++) - values[i] = recursiveSolve(board, width, height, pos, board[pos], directions[i], 0); - - int joinedValues[4] = { - values[0] + values[4], - values[1] + values[5], - values[2] + values[6], - values[3] + values[7] - }; - - bool won = false; - for (int i = 0; i < 4; i++) { - if (joinedValues[i] >= 3) { - won = won || true; - - int start_pos = pos + directions[i+0] * values[i+0]; - int end_pos = pos + directions[i+4] * values[i+4]; - printf("w:%d-%d\n", start_pos, end_pos); - fflush(stdout); - } - } - - return won; -} - -bool dropFisje(int board[], int width, int height, int column, int disc) { - for (int row = 0; row < height; row++) { - int pos = column + row * width; - if (board[pos] == 0) { - board[pos] = disc; - bool won = checkWin(board, width, height, pos); - return true; // success - } - } - printf("e:full\n"); - fflush(stdout); - return false; // unsuccessful drop on board full -} - -int main() { - int width, height; - scanf("%d %d", &width, &height); - - int board[width * height]; - memset(board, 0, sizeof board); - - bool player_1 = true; - int move = 0; - while (scanf("%d", &move) == 1) { - if (move == 0) break; - if (move < 1 || move > width) continue; - - bool dropSuccess = dropFisje(board, width, height, move - 1, player_1 + 1); - - player_1 = player_1 ^ dropSuccess; // only flip turns on successful drop - printf("m:%s\n", player_1 ? "true" : "false"); - fflush(stdout); - - printBoard(board, width, height); - } - - return 0; -} diff --git a/console/voerbak_connector.py b/console/voerbak_connector.py deleted file mode 100644 index 6274ada..0000000 --- a/console/voerbak_connector.py +++ /dev/null @@ -1,79 +0,0 @@ -from colorama import Fore -import logging as log -import subprocess -import os - -VERBOSE = log.ERROR -log.basicConfig(format="[ %(levelname)s ]: %(message)s", level=VERBOSE) - -DISC_SHAPE = "o" -DISC_A = Fore.RED + DISC_SHAPE + Fore.RESET -DISC_B = Fore.BLUE + DISC_SHAPE + Fore.RESET -EMPTY = Fore.LIGHTBLACK_EX + "_" + Fore.RESET - -VOERBAK_LOCATION = "./voerbak" -if os.name == "nt": VOERBAK_LOCATION += ".exe" - -class bord: - def __init__(self, w, h): - self.width = w - self.height = h - self.player_1 = True - self.board = "0" * (w * h) - self.win_positions = [] - self.process = subprocess.Popen(["./voerbak"], - stdin=subprocess.PIPE, - stdout=subprocess.PIPE, - stderr=None) - self.process.stdin.write(bytearray(f"{w} {h}\n", "utf-8")) - self.process.stdin.flush() - - def get_output(self): - return self.process.stdout.readline().decode()[:-1] - - def update_board(self): - buffer = self.get_output() - while not buffer.isdigit(): - if buffer.startswith("w:"): - self.win_positions.append(buffer[2:].split("-")) - log.info(f"won: {buffer[2:].split('-')}") - elif buffer.startswith("e:"): - log.warning(buffer[2:]) - elif buffer.startswith("m:"): - substr = buffer[2:] - self.player_1 = True if substr == "true" else False - buffer = self.get_output() - self.board = buffer - - def print(self): - for y in range(self.height -1, -1, -1): - for x in range(self.width): - state = self.board[x + y * self.width] - char = [EMPTY, - DISC_A, - DISC_B - ] - print(char[int(state)], end=" ") - print("\n", end="") - - def drop_fisje(self, column): - self.process.stdin.write(bytearray(f"{column}\n", "utf-8")) - self.process.stdin.flush() - self.update_board() - -def main(): - gert = bord(7, 6) - while True: - print(gert.player_1) - if len(gert.win_positions) > 0: - print(f"won: {gert.win_positions}") - exit(0) - gert.print() - column = int(input("column?: ")) - 1 - if column not in range(gert.width): - continue - gert.drop_fisje(column + 1) - -if __name__ == "__main__": - main() - |