1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
#include <stdio.h>
#include <stdlib.h>
#include <memory.h>
#include <stdbool.h>
#define DISC_A "\x1b[31mo\x1b[39m"
#define DISC_B "\x1b[34mo\x1b[39m"
#define EMPTY "\x1b[90m_\x1b[39m"
void printBoard(int board[], int width, int height) {
for (int y = height - 1; y > -1; y--) {
for (int x = 0; x < width; x++) {
int val = board[x + y * width];
char *print =
val == 0 ? EMPTY :
val == 1 ? DISC_A :
val == 2 ? DISC_B :
EMPTY;
printf("%s ", print);
}
printf("\n");
}
}
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 = true;
break;
}
}
return won;
}
void 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);
printf(won ? "true" : "false");
printf("\n");
return;
}
}
}
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;
dropFisje(board, width, height, move - 1, player_1 + 1);
player_1 = !player_1;
}
printBoard(board, width, height);
return 0;
}
|