c语言 写一个五子棋

c语言

IsWin判赢

display 画 10 x 10 的棋盘

判断落子的坐标是否已有棋子

判断落子坐标范围是否超出范围

cpp 复制代码
// 五子棋
#include <stdio.h>
#include <stdlib.h>

// 画棋盘 10 x 10的棋盘,len为行数
void display(char map[][10], int len)
{
	system("clear");
	printf("   0 1 2 3 4 5 6 7 8 9\n");
	for (int i = 0; i < len; i++) {
		printf("%d ", i);
		for (int j = 0; j < 10; j++) {
			printf("|%c", map[i][j]);
		}
		printf("|\n");
	}
}

// 判断是否赢棋
int IsWin(char map[][10], int len, int x, int y)
{
	int xx;
	int yy;
	int saves = 0;
	int count = 1;
	// 判断是否棋盘下满
	for (int i = 0; i < len; i++) {
		for (int j = 0; j < 10; j++) {
			if (map[i][j] == ' ') {
				saves += 1;
			}
		}
	}
	if (saves == 0) {
		printf("棋盘下满,平局!\n");
		return -1;
	}
	//判断赢棋,从横、纵、斜、反斜四个方向判断
	// 横向判断
	// count == 1 是因为下面 for循环判断是从坐标的横移左一个、横移右一个开始判断的
    for (yy = y-1; yy > -1; yy--) {
		if (map[x][yy] == map[x][y] && map[x][y] != ' ') {
			count += 1;
		}
	}
	for (yy = y+1; yy < 10; yy++) {
		if (map[x][yy] == map[x][y] && map[x][y] != ' ') {
			count += 1;
		}
	}
	if (count >= 5) {
		if (map[x][y] == 'O') {
			printf("白棋赢\n");
			return 1;
		} else {
			printf("黑棋赢\n");
			return 2;
		}
	}
    count = 1;
	// 纵向判断
    for (xx = x-1; xx > -1; xx--) {
		if (map[xx][y] == map[x][y] && map[x][y] != ' ') {
			count += 1;
		}
	}
	for (xx = x+1; xx < len; xx++) {
		if (map[xx][y] == map[x][y] && map[x][y] != ' ') {
			count += 1;
		}
	}
	if (count >= 5) {
		if (map[x][y] == 'O') {
			printf("白棋赢\n");
			return 1;
		} else {
			printf("黑棋赢\n");
			return 2;
		}
	}
    count = 1;
	// 反斜方向判断
    for (xx = x-1,yy = y + 1; xx > -1 && yy < 10; xx--,yy++) {
		if (map[xx][yy] == map[x][y] && map[x][y] != ' ') {
			count += 1;
		}
	}
	for (xx= x+1,yy = y-1; xx < len && yy > -1; yy--,xx++) {
		if (map[xx][yy] == map[x][y] && map[x][y] != ' ') {
			count += 1;
		}
	}
	if (count >= 5) {
		if (map[x][y] == 'O') {
			printf("白棋赢\n");
			return 1;
		} else {
			printf("黑棋赢\n");
			return 2;
		}
	}
    count = 1;
	// 斜线 方向判断
    for (xx = x-1,yy = y - 1; xx > -1 && yy > -1; xx--,yy--) {
		if (map[xx][yy] == map[x][y] && map[x][y] != ' ') {
			count += 1;
		}
	}
	for (xx= x+1,yy = y+1; xx < len && yy < 10; yy++,xx++) {
		if (map[xx][yy] == map[x][y] && map[x][y] != ' ') {
			count += 1;
		}
	}
	if (count >= 5) {
		if (map[x][y] == 'O') {
			printf("白棋赢\n");
			return 1;
		} else {
			printf("黑棋赢\n");
			return 2;
		}
	}
	return 0;
}

int main(void)
{
	char map[10][10] = {};
        for (int i = 0; i < 10; i++) {
            for (int j = 0; j < 10; j++) {
                map[i][j] = ' ';
            }
        }
	display(map, 10);
	int x = 0, y = 0,ret = -1;
	while (1) {
		while (1) {
	        printf("白旗落子\n"); // 'O'
	        printf("请输入横坐标:");
	        scanf("%d", &x);
	        printf("请输入纵坐标:");
	        scanf("%d", &y);
	        if (x >= 0 && x <= 9 && y >=0 && y <= 9) {
	            if (map[x][y] != ' ') {
		    	    printf("该坐标已落子,请重新输入坐标\n");
		    		continue;
		    	} else {
		    		map[x][y] = 'O';
	                display(map, 10);
					break;
		    	}
	        }
		    else {
		    	printf("输入坐标超出棋盘范围,请重新输入\n");
		    	continue;
		    }
		}
        ret = IsWin(map, 10, x, y);
		if (ret != 0) {
			break;
		}
		while (1) {
	        printf("黑旗落子\n"); // 'X'
	        printf("请输入横坐标:");
	        scanf("%d", &x);
	        printf("请输入纵坐标:");
	        scanf("%d", &y);
	        if (x >= 0 && x <= 9 && y >=0 && y <= 9) {
	            if (map[x][y] != ' ') {
		    	    printf("该坐标已落子,请重新输入坐标!\n");
		    		continue;
		    	} else {
		    		map[x][y] = 'X';
	                display(map, 10);
					break;
		    	}
	        }
		    else {
		    	printf("输入坐标超出棋盘范围,请重新输入!\n");
		    	continue;
		    }
		}
        ret = IsWin(map, 10, x, y);
        if (ret != 0) {
            break;
		}
	}
	return 0;
}    

     
相关推荐
CSDN_RTKLIB12 小时前
CMake几个命令顺序
c++
Evand J12 小时前
【MATLAB例程,附代码下载链接】基于累积概率的三维轨迹,概率计算与定位,由轨迹匹配和滤波带来高精度位置,带测试结果演示
开发语言·算法·matlab·csdn·轨迹匹配·候选轨迹·完整代码
X在敲AI代码12 小时前
LeetCode 基础刷题D2
算法·leetcode·职场和发展
源代码•宸12 小时前
Leetcode—1929. 数组串联&&Q1. 数组串联【简单】
经验分享·后端·算法·leetcode·go
数据大魔方12 小时前
【期货量化实战】跨期套利策略:价差交易完整指南(TqSdk源码详解)
数据库·python·算法·github·程序员创富
weixin_4617694012 小时前
15. 三数之和
c++·算法·leetcode·三数之和
NAGNIP12 小时前
一文搞懂机器学习中的学习理论!
算法·面试
Evand J12 小时前
【MATLAB代码介绍】基于累积概率的三维轨迹匹配与定位,由轨迹匹配和卡尔曼滤波形成算法,带测试结果演示
算法·matlab·滤波·定位·导航·轨迹匹配
l1t12 小时前
NineData第三届数据库编程大赛:用一条 SQL 解数独问题我的参赛程序
数据库·人工智能·sql·算法·postgresql·oracle·数独
千金裘换酒12 小时前
LeetCode 链表两数相加
算法·leetcode·链表