You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

226 lines
5.7 KiB

2 years ago
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <unistd.h>
#include <assert.h>
2 years ago
/* Game Specific defines */
2 years ago
#define ROWS 7
#define COLUMNS 6
#define TIME 0.6
2 years ago
#define PLAYER1 '0'
#define PLAYER2 'X'
2 years ago
2 years ago
/* Printf colour defines */
2 years ago
#define BOLDYELLOW "\033[1m\033[33m" /* Bold Yellow */
2 years ago
#define BOLDRED "\033[1m\033[31m" /* Bold Red */
2 years ago
#define BOLDWHITE "\033[1m\033[37m" /* Bold White */
#define RESET "\033[0m"
2 years ago
/* Global board, saves passing 2D array pointers */
2 years ago
char board[ROWS][COLUMNS];
void print_board();
void clear_board();
2 years ago
void player_choice(char player);
2 years ago
void ai_choice(char player);
2 years ago
char check_win();
2 years ago
int check_free_space();
char flag = ' ';
2 years ago
int main(int argc, char *argv[]){
clear_board();
while(check_free_space() != 0 && flag == ' '){
2 years ago
print_board();
player_choice(PLAYER1);
flag = check_win();
2 years ago
print_board();
player_choice(PLAYER2);
flag = check_win();
2 years ago
}
2 years ago
printf(BOLDWHITE "%c won!" RESET, flag);
2 years ago
return 0;
}
void print_board(){
int r, c;
c = 0;
2 years ago
system("clear");
//printf("\nFree Spaces: %d\n", check_free_space());
2 years ago
2 years ago
printf(BOLDWHITE " 1 2 3 4 5 6 \n" RESET);
2 years ago
2 years ago
for(r = 0; r < ROWS; ++r){
for(c = 0; c < COLUMNS; ++c){
2 years ago
//PLAYER 1 COLOURS
if(board[r][c] == PLAYER1){
2 years ago
printf("[ ");
printf(BOLDRED "%c" RESET ,board[r][c]);
printf(" ]");
}
2 years ago
//PLAYER 2 COLOURS
else if(board[r][c] == PLAYER2){
2 years ago
printf("[ ");
printf(BOLDYELLOW "%c" RESET ,board[r][c]);
printf(" ]");
}
else{
printf("[ %c ]", board[r][c]);
}
}
printf("\n");
}
}
void clear_board(){
int r, c;
for(r = 0; r < ROWS; ++r){
for(c = 0; c < COLUMNS; ++c){
board[r][c] = ' ';
}
}
}
void player_choice(char player){
unsigned int frametime = 30000;
int chosenCol;
2 years ago
2 years ago
printf(BOLDWHITE "\n[%c] Enter column (1-6)\n> " RESET, player);
scanf("%d", &chosenCol);
2 years ago
if(chosenCol > 6){
2 years ago
printf(BOLDRED "\n[%c] Cannot play here, skipping...\n" RESET, player);
sleep(1);
} else {
chosenCol--; //arrays start with 0
for(int r = 0; board[r][chosenCol] == ' '; ++r){
2 years ago
// Check if the next tile is not empty (occupied)
if(board[r+1][chosenCol] != ' '){
board[r][chosenCol] = player;
2 years ago
break;
}
//check if we've hit the last row
if(r >= COLUMNS){
board[r][chosenCol] = player;
2 years ago
break;
}
// Animation for dropping the piece down
board[r][chosenCol] = player;
2 years ago
print_board();
usleep(frametime);
board[r][chosenCol] = ' ';
2 years ago
print_board();
usleep(frametime);
2 years ago
}
}
}
2 years ago
2 years ago
void ai_choice(char player){
//TODO: Implement ""AI""
2 years ago
}
2 years ago
2 years ago
char check_win(){
char flag = ' ';
2 years ago
//no i know there is a better way to check for a win cond.
//buuttt ill do what i wanna
//and repeat all the checks twice (player 1 and player 2)!
//check vert
for(int i = 0; i < COLUMNS; ++i) {
for(int j = 0; j < ROWS; ++j) {
if(board[i][j] == PLAYER1 && board[i][j+1] == PLAYER1 && board[i][j+2] == PLAYER1 && board[i][j+3] == PLAYER1){
flag = PLAYER1;
}
}
}
//check horiz
for(int i = 0; i < ROWS; ++i) {
for(int j = 0; j < COLUMNS; ++j) {
if(board[i][j] == PLAYER1 && board[i+1][j] == PLAYER1 && board[i+2][j] == PLAYER1 && board[i+3][j] == PLAYER1){
flag = PLAYER1;
}
}
}
//check diagright
for(int i = 0; i < ROWS; ++i){
for(int j = 0; j < COLUMNS; ++j) {
if(board[i][j] == PLAYER1 && board[i-1][j+1] == PLAYER1 && board[i-2][j+2] == PLAYER1 && board[i-3][j+3] == PLAYER1){
flag = PLAYER1;
}
}
}
//check diagleft
for(int i = 0; i < ROWS; ++i){
for(int j = 0; j < COLUMNS; ++j) {
if(board[i][j] == PLAYER1 && board[i-1][j-1] == PLAYER1 && board[i-2][j-2] == PLAYER1 && board[i-3][j-3] == PLAYER1){
flag = PLAYER1;
}
}
}
//check vert
for(int i = 0; i < COLUMNS; ++i) {
for(int j = 0; j < ROWS; ++j) {
if(board[i][j] == PLAYER2 && board[i][j+1] == PLAYER2 && board[i][j+2] == PLAYER2 && board[i][j+3] == PLAYER2){
flag = PLAYER2;
}
}
}
//check horiz
for(int i = 0; i < ROWS; ++i) {
for(int j = 0; j < COLUMNS; ++j) {
if(board[i][j] == PLAYER2 && board[i+1][j] == PLAYER2 && board[i+2][j] == PLAYER2 && board[i+3][j] == PLAYER2){
flag = PLAYER2;
}
}
}
//check diagright
for(int i = 0; i < ROWS; ++i){
for(int j = 0; j < COLUMNS; ++j) {
if(board[i][j] == PLAYER2 && board[i-1][j+1] == PLAYER2 && board[i-2][j+2] == PLAYER2 && board[i-3][j+3] == PLAYER2){
flag = PLAYER2;
}
}
}
//check diagleft
for(int i = 0; i < ROWS; ++i){
for(int j = 0; j < COLUMNS; ++j) {
if(board[i][j] == PLAYER2 && board[i-1][j-1] == PLAYER2 && board[i-2][j-2] == PLAYER2 && board[i-3][j-3] == PLAYER2){
flag = PLAYER2;
}
}
}
2 years ago
2 years ago
return flag;
2 years ago
}
int check_free_space(){
int r, c;
int sp = 0;
2 years ago
2 years ago
for(r = 0; r < ROWS; ++r){
for(c = 0; c < COLUMNS; ++c){
2 years ago
if(board[r][c] == ' ')
++sp;
2 years ago
}
}
return sp;
}