news 2026/5/26 1:28:28

##三子棋

作者头像

张小明

前端开发工程师

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/5/24 7:03:07

python之知识图谱(networkx)

NetworkX 库介绍与使用指南 NetworkX 是 Python 中用于创建、操作和分析复杂网络&#xff08;图结构&#xff09; 的核心库&#xff0c;支持无向图、有向图、加权图、多重图等多种图类型&#xff0c;内置丰富的图算法&#xff08;路径分析、连通性、中心性、社区检测等&#xf…

作者头像 李华
网站建设 2026/5/25 1:16:03

【技术教程】2025年Python GUI框架选型终极指南

2025年Python GUI框架选型终极指南&#xff08;最新版&#xff09; 以下内容基于2024-2025年真实社区动态与企业实践整理&#xff0c;已反映当前最准确的格局与趋势。 一、2025年Python GUI框架最新格局总览框架当前地位主要变化与趋势&#xff08;2025&#xff09;GitHub星标&…

作者头像 李华
网站建设 2026/5/25 12:46:12

AI代码生成终极指南:OpenReasoning-Nemotron-14B快速上手教程

AI代码生成终极指南&#xff1a;OpenReasoning-Nemotron-14B快速上手教程 【免费下载链接】OpenReasoning-Nemotron-14B 项目地址: https://ai.gitcode.com/hf_mirrors/nvidia/OpenReasoning-Nemotron-14B 在当今软件开发领域&#xff0c;AI代码生成技术正在彻底改变传…

作者头像 李华
网站建设 2026/5/25 23:43:20

在电机控制领域,永磁同步电机(PMSM)的无位置传感器控制一直是一个热门话题。今天,我们就来聊聊如何在工程中实现这一技术,特别是低速和高速度下的控制策略

永磁同步电机无位置传感器算法仿真&#xff0c;低速IF中高速龙贝格观测器&#xff0c;这是工程中最常用最成熟的方法。 低速采用流频比IF控制&#xff0c;转速开环&#xff0c;电流闭环&#xff0c;转速和位置角度使用参考转速和计算的参考位置。 中高速采用了基于龙贝格观测器…

作者头像 李华
网站建设 2026/5/25 7:20:13

在家也能组乐队?ACE-Step 加上cpolar远程做歌超顺手

文章目录前言1、关于ACE-Step2、windows本地部署3、简单使用ACE-Step4、介绍以及安装cpolar5、配置公网地址6、配置固定二级子域名公网地址结尾前言 ACE-Step 主要功能是基于 AI 算法生成原创歌曲&#xff0c;支持中文、英文等 19 种语言&#xff0c;输入关键词或歌词就能生成…

作者头像 李华
网站建设 2026/5/25 1:27:52

揭秘Dify Agent工具注册黑盒:3个关键接口与注册流程全拆解

第一章&#xff1a;揭秘Dify Agent工具注册机制的核心价值Dify Agent作为连接AI模型与业务系统的桥梁&#xff0c;其注册机制在系统可扩展性与安全性方面扮演着关键角色。该机制不仅确保了每个Agent的身份唯一性&#xff0c;还通过标准化的接入流程实现了动态发现与权限控制&am…

作者头像 李华