news 2026/4/3 6:32:49

##三子棋

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
##三子棋

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

// 定义棋盘大小(3x3)
#define ROW 3
#define COL 3

// 函数声明
void InitBoard(char board[ROW][COL], int row, int col); // 初始化棋盘
void DisplayBoard(char board[ROW][COL], int row, int col); // 打印棋盘
void PlayerMove(char board[ROW][COL], int row, int col); // 玩家落子(X)
void ComputerMove(char board[ROW][COL], int row, int col); // 电脑落子(O)
char IsWin(char board[ROW][COL], int row, int col); // 判断胜负
int IsFull(char board[ROW][COL], int row, int col); // 判断棋盘是否满

int main() {
char board[ROW][COL];
char result = 0;
srand((unsigned int)time(NULL)); // 初始化随机数种子(用于电脑落子)

InitBoard(board, ROW, COL); // 初始化棋盘
DisplayBoard(board, ROW, COL); // 打印初始棋盘

// 游戏循环:直到分出胜负或平局
while (1) {
PlayerMove(board, ROW, COL); // 玩家落子
DisplayBoard(board, ROW, COL);
result = IsWin(board, ROW, COL); // 判断玩家是否获胜
if (result != 0) break; // 有结果则退出循环

ComputerMove(board, ROW, COL); // 电脑落子
DisplayBoard(board, ROW, COL);
result = IsWin(board, ROW, COL); // 判断电脑是否获胜
if (result != 0) break; // 有结果则退出循环
}

// 输出游戏结果
if (result == 'X') {
printf("恭喜!你赢了!\n");
} else if (result == 'O') {
printf("很遗憾,电脑赢了!\n");
} else if (result == 'Q') {
printf("游戏平局!\n");
}

return 0;
}

// 初始化棋盘:所有位置设为空格(便于后续落子和打印)
void InitBoard(char board[ROW][COL], int row, int col) {
int i = 0;
int j = 0;
for (i = 0; i < row; i++) {
for (j = 0; j < col; j++) {
board[i][j] = ' ';
}
}
}

// 打印棋盘:格式为 1 | 2 | 3 样式,清晰区分行列
void DisplayBoard(char board[ROW][COL], int row, int col) {
int i = 0;
int j = 0;
for (i = 0; i < row; i++) {
// 打印一行的棋子
for (j = 0; j < col; j++) {
printf(" %c ", board[i][j]);
if (j != col - 1) { // 最后一列不打印竖线
printf("|");
}
}
printf("\n");
// 打印行分隔线(最后一行不打印)
if (i != row - 1) {
for (j = 0; j < col; j++) {
printf("---");
if (j != col - 1) {
printf("|");
}
}
printf("\n");
}
}
}

// 玩家落子:输入坐标(1-3),需判断坐标合法且位置未被占用
void PlayerMove(char board[ROW][COL], int row, int col) {
int x = 0;
int y = 0;
printf("你的回合(落子X):请输入坐标(例如 1 1):");

while (1) {
// 输入坐标(玩家习惯1开始,需转换为数组0开始)
scanf("%d %d", &x, &y);
x--;
y--;

// 判断坐标是否在合法范围内
if (x >= 0 && x < row && y >= 0 && y < col) {
// 判断该位置是否为空
if (board[x][y] == ' ') {
board[x][y] = 'X'; // 落子
break;
} else {
printf("该位置已被占用,请重新输入!\n");
}
} else {
printf("坐标非法(需1-3),请重新输入!\n");
}
}
}

// 电脑落子:随机生成坐标(0-2),仅在空位置落子(O)
void ComputerMove(char board[ROW][COL], int row, int col) {
int x = 0;
int y = 0;
printf("电脑回合(落子O):\n");

while (1) {
// 随机生成合法范围内的坐标
x = rand() % row; // 0-2
y = rand() % col; // 0-2
// 判断位置是否为空
if (board[x][y] == ' ') {
board[x][y] = 'O'; // 落子
break;
}
}
}

// 判断棋盘是否满:满则返回1(平局),否则返回0
int IsFull(char board[ROW][COL], int row, int col) {
int i = 0;
int j = 0;
for (i = 0; i < row; i++) {
for (j = 0; j < col; j++) {
if (board[i][j] == ' ') {
return 0; // 存在空格,棋盘未满
}
}
}
return 1; // 棋盘已满
}

// 判断胜负:返回'X'(玩家赢)、'O'(电脑赢)、'Q'(平局)、0(继续)
char IsWin(char board[ROW][COL], int row, int col) {
int i = 0;

// 1. 判断所有行是否相同(且不为空格)
for (i = 0; i < row; i++) {
if (board[i][0] == board[i][1] && board[i][1] == board[i][2] && board[i][0] != ' ') {
return board[i][0];
}
}

// 2. 判断所有列是否相同(且不为空格)
for (i = 0; i < col; i++) {
if (board[0][i] == board[1][i] && board[1][i] == board[2][i] && board[0][i] != ' ') {
return board[0][i];
}
}

// 3. 判断两条对角线是否相同(且不为空格)
if (board[0][0] == board[1][1] && board[1][1] == board[2][2] && board[0][0] != ' ') {
return board[0][0];
}
if (board[0][2] == board[1][1] && board[1][1] == board[2][0] && board[0][2] != ' ') {
return board[0][2];
}

// 4. 判断是否平局(棋盘满且未分胜负)
if (IsFull(board, row, col) == 1) {

return 'Q' ;

}

//5.游戏继续(无结果)

return 0 ;

}

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/1 3:57:09

如何快速实现绘图仪风格艺术:Pintr完整使用指南

如何快速实现绘图仪风格艺术&#xff1a;Pintr完整使用指南 【免费下载链接】pintr Create single line illustrations from your pictures. Get a drawing, SVG or coordinates for a CNC. 项目地址: https://gitcode.com/gh_mirrors/pi/pintr Pintr是一个创新的开源工…

作者头像 李华
网站建设 2026/3/30 12:38:57

如何快速构建专业K线图表:vnpy图表模块5个核心组件详解

如何快速构建专业K线图表&#xff1a;vnpy图表模块5个核心组件详解 【免费下载链接】vnpy 基于Python的开源量化交易平台开发框架 项目地址: https://gitcode.com/vnpy/vnpy 你是否在量化交易中遇到过数据可视化难题&#xff1f;想要一个既能展示专业K线图表&#xff0c…

作者头像 李华
网站建设 2026/3/31 10:03:50

DAY 36 简单的神经网络

一、PyTorch和cuda的安装 二、查看显卡信息的命令行命令&#xff08;cmd中&#xff09; 三、cuda的检查 import torch# 检查CUDA是否可用 if torch.cuda.is_available():print("CUDA可用&#xff01;")# 获取可用的CUDA设备数量device_count torch.cuda.device_c…

作者头像 李华
网站建设 2026/3/31 13:40:37

多场景配置,高进度控光:HTR3229 LED 驱动芯片

在智能电子设备飞速发展的今天&#xff0c;LED 显示作为人机交互的重要窗口&#xff0c;对驱动芯片的灵活性、精准度和稳定性提出了越来越高的要求。HTR3229 作为一款高集成度、多功能的 LED 驱动芯片&#xff0c;凭借其灵活的阵列配置、细腻的调光控制、可靠的故障检测及优异的…

作者头像 李华
网站建设 2026/4/3 4:59:58

初识C语言(数据在内存中的存储)

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录前言这篇博客主要围绕整数、大小端字节序、浮点数在内存中的存储。一、整数在内存中的存储1. 二进制表示形式2. 存储方式3. 常见整数类型4. 特殊整数处理5. 内存布局…

作者头像 李华
网站建设 2026/3/27 14:10:01

openEuler在WSL2中的GPU加速AI训练实战指南

本文基于openEuler在WSL2环境中的实际部署经验&#xff0c;提供完整的GPU加速AI训练解决方案。通过优化CUDA工具链安装、TensorFlow GPU版部署及实战训练&#xff0c;验证openEuler在WSL2中对NVIDIA GPU的完美支持&#xff0c;为开发者提供可复现的云端AI开发环境。 一、WSL2环…

作者头像 李华