一个10*10的矩阵(可以理解为棋盘),随时生成一组数据填入矩阵,任何一个位置的数字除4进行计算,按余数着色,余数为0着色为red,1为blue,2为green,3为black,可以理解为生成4中颜色的棋子放入棋盘,如果存在其中同色五星连珠的情况(规则通五子棋),找出任意一组,输出5个棋子的位置下标值。
bool FindInRow(int* a, int row, int col)
{
int i = 0;
int j = 0;
int pre;
int cnt;
for (; i < row; i++)
{
pre = *(a + i*col + j) % 4;
cnt = 1;
for (j = 1; j < col; j++)
{
if (*(a + i*col + j) % 4 == pre)
{
cnt++;
}
else
{
cnt = 1;
pre = *(a + i*col + j);
}
if (cnt >= 5)
{
return true;
}
}
}
return false;
}
bool FindInCol(int *a, int row, int col)
{
int i = 0;
int j = 0;
int pre;
int cnt;
for (; j < col; j++)
{
pre = *(a + i*col + j) % 4;
cnt = 1;
for (i = 1; i < row; i++)
{
if (*(a + i*col + j) % 4 == pre)
{
cnt++;
}
else
{
cnt = 1;
pre = *(a + i*col + j);