cmpsc330hw4/board.cpp

164 lines
5.0 KiB
C++
Raw Normal View History

2024-11-19 23:54:26 +00:00
#include "board.h"
#include <iostream>
#include <cctype>
using namespace std;
Board::Board(int rows, int cols) : rows(rows), cols(cols) {
// Allocate memory for the 2D board
board = new char*[2 * rows - 1];
for (int i = 0; i < 2 * rows - 1; i++) {
board[i] = new char[2 * cols - 1];
for (int j = 0; j < 2 * cols - 1; j++) {
// Initialize with dots at intersections and spaces elsewhere
board[i][j] = (i % 2 == 0 && j % 2 == 0) ? '.' : ' ';
}
}
}
Board::~Board() {
// TODO: use free
// Free dynamically allocated memory
for (int i = 0; i < 2 * rows - 1; i++) {
delete[] board[i];
}
delete[] board;
}
char Board::get(int row, int col) const {
return board[row][col];
}
void Board::set(int row, int col, char value) {
board[row][col] = value;
}
bool Board::isLineValid(int row, int col) const {
// A line is valid if it's in a valid position and not already occupied
return (row > - 1 && row < 2 * rows - 1 && col > -1 && col < 2 * cols - 1) &&
((row&1) != (col&1)) && (board[row][col] == ' ');
}
void Board::placeLine(int row, int col, char player) {
if (isLineValid(row, col)) {
board[row][col] = tolower(player); // Place the player's initial in lowercase
}
}
int Board::checkAndMarkBox(int row, int col, char player) {
int completedBoxes = 0;
// Check if the move is horizontal or vertical
bool isHorizontal = (row % 2 == 0);
if (isHorizontal) {
// Check box above the line (if row > 0)
if (row > 0 &&
board[row - 2][col] != ' ' && // Top line
board[row][col] != ' ' && // Bottom line
board[row - 1][col - 1] != ' ' && // Left line
board[row - 1][col + 1] != ' ') { // Right line
board[row - 1][col] = player; // Mark box with player's initial
completedBoxes++;
}
// Check box below the line (if row < 2 * rows - 2)
if (row < 2 * rows - 2 &&
board[row + 2][col] != ' ' && // Bottom line
board[row][col] != ' ' && // Top line
board[row + 1][col - 1] != ' ' && // Left line
board[row + 1][col + 1] != ' ') { // Right line
board[row + 1][col] = player; // Mark box with player's initial
completedBoxes++;
}
} else {
// Check box to the left (if col > 0)
if (col > 0 &&
board[row - 1][col - 1] != ' ' && // Top line
board[row + 1][col - 1] != ' ' && // Bottom line
board[row][col - 2] != ' ' && // Left line
board[row][col] != ' ') { // Right line
board[row][col - 1] = player; // Mark box with player's initial
completedBoxes++;
}
// Check box to the right (if col < 2 * cols - 2)
if (col < 2 * cols - 2 &&
board[row - 1][col + 1] != ' ' && // Top line
board[row + 1][col + 1] != ' ' && // Bottom line
board[row][col + 2] != ' ' && // Right line
board[row][col] != ' ') { // Left line
board[row][col + 1] = player; // Mark box with player's initial
completedBoxes++;
}
}
return completedBoxes;
}
bool Board::isFull() const {
for (int i = 0; i < 2 * rows - 1; i++) {
for (int j = 0; j < 2 * cols - 1; j++) {
if (board[i][j] == ' ' && (i % 2 != j % 2)) {
return false; // There's at least one empty line
}
}
}
return true;
}
void Board::printBoard() const {
// Function to print the board
// Print the tens and ones places of the column numbers
cout << " "; // Space for row numbers
for (int col = 0; col < cols * 2 - 1; ++col) {
if (!(col % 10)) {
cout << col / 10; // Tens place of column numbers
} else {
cout << " "; // For spaces between dots
}
}
cout << endl;
// Print the ones place of the column numbers
cout << " "; // Space for row numbers
for (int col = 0; col < cols * 2 - 1; ++col) {
cout << (col) % 10; // Print ones place
}
cout << endl;
// Print the board rows with row numbers
for (int row = 0; row < rows * 2 - 1; ++row) {
// Print row number on the left
if (row / 10 > 9) {
if (row % 10 == 0) {
cout << row / 10;
} else {
cout << " ";
}
} else {
if (row % 10 == 0) {
cout << row / 10;
} else {
cout << " ";
}
}
cout << row % 10 << " "; // Print the ones place of the row number
// Print the content of the row (dots, lines, spaces)
for (int col = 0; col < cols * 2 - 1; ++col) {
cout << board[row][col];
}
cout << endl;
}
}
int Board::getRows() const {
return rows;
}
int Board::getCols() const {
return cols;
}