摘要:三子棋代码耗时三天,本人很菜,疯狂不细心写代码真的很累本代码使用编译所以使用了懂得都懂如果使用别的编译器请注意将起改为宏定义行数为为行,为列不会列的英文宏定义列数为也可以改为大棋盘,但要更改游戏机制初始
**本代码使用vs2019编译
所以使用了scanf_s(懂得都懂)
如果使用别的编译器请注意将起改为scanf
#include #include #include #define ROW 3//宏定义行数为3 ROW为行,LIE为列(不会列的英文)#define LIE 3//宏定义列数为3,也可以改为大棋盘,但要更改游戏机制void aBoard(char board[ROW][LIE], int row, int lie);//初始化棋子void printBoard(char board[ROW][LIE], int row, int lie);// 打印棋盘void Playergo(char board[ROW][LIE], int row, int lie); //人走void Computergo(char board[ROW][LIE], int row, int lie);//电脑走char ifWin(char board[ROW][LIE], int row, int lie);//判断输赢void menu(void);//菜单void test(void);//void game(void);//核心int main(void){ test(); return 0;}void game(void){ char p = 0; char board[ROW][LIE] = { 0 };//我也不知道为什么不能用‘ ’; //初始化棋子为空格 aBoard(board, ROW, LIE); //打印棋盘 printBoard(board, ROW, LIE); while (2)//非0的数字就可以 { //玩家下棋 Playergo(board, ROW, LIE); printBoard(board, ROW, LIE); //判断玩家是否胜利 p = ifWin(board, ROW, LIE); if (p != "C") { break; } //电脑下棋 Computergo(board, ROW, LIE); printBoard(board, ROW, LIE); //判断电脑是否胜利 p = ifWin(board, ROW, LIE); if (p != "C") { break; } } if (p == "*") { printf("YOU WIN/n"); printf("/n"); } else if (p == "#") { printf("COMPUTER WIN!/n"); printf("/n"); }}//游戏菜单void menu(void){ printf("-----------------------------------------------/n"); printf("-----------------------------------------------/n"); printf("*****输入1.开始游戏 输入0.退出游戏*****/n"); printf("-----------------------------------------------/n"); printf("-----------------------------------------------/n");}//初始化棋盘void aBoard(char board[ROW][LIE], int row, int lie){ for (int i = 0; i < row; i++) { for (int j = 0; j < lie; j++) { board[i][j] = " "; } }}//打印棋盘void printBoard(char board[ROW][LIE], int row, int lie){ for (int i = 0; i < row; i++) { for (int j = 0; j < lie; j++) { if (j < lie - 1) { printf(" %c |", board[i][j]); } else printf(" %c ", board[i][j]); } printf("/n"); if (i < row - 1) { for (int k = 0; k < lie; k++) { if (k < lie - 1) { printf("---|"); } else { printf("---"); } } } printf("/n"); }}//玩家输入void Playergo(char board[ROW][LIE], int row, int lie){ int x = 0; int y = 0; while (1)//同上 { printf("系统提示:请输入您要下的坐标"); printf("坐标之间用空格隔开"); scanf_s("%d%d", &x, &y); printf("/n"); //判断xy是否合法,一个是是否超出,一个是是否被占用 if (x > 0 && x < row + 1 && y>0 && y < lie + 1) { if (board[x - 1][y - 1] == " ") { board[x - 1][y - 1] = "*"; break; } else { printf("坐标被占用,请重新输入/n"); printf("/n"); } } else { printf("超出坐标范围,输入的横纵都坐标为1到3;/n/n"); } }}void Computergo(char board[ROW][LIE], int row, int lie){ int x = 0; int y = 0; printf("本电脑走的飞快/n/n"); while (1) { x = rand() % row; y = rand() % lie; if (board[x][y] == " ") { board[x][y] = "#"; break; } }}//判断胜负char ifWin(char board[ROW][LIE], int row, int lie){ int i = 0; //判断行 for (i = 0; i < row; i++) { if (board[i][0] == board[i][1] && board[i][1] == board[i][2] && board[i][1] != " ") { return board[i][1]; } } //判断列 for (i = 0; i < lie; i++) { if (board[0][i] == board[1][i] && board[1][i] == board[2][i] && board[1][i] != " ") { return board[1][i]; } } //判断对角线 if (board[0][0] == board[1][1] && board[1][1] == board[2][2] && board[1][1] != " ") { return board[1][1]; } if (board[2][0] == board[1][1] && board[1][1] == board[0][2] && board[1][1] != " ") { return board[1][1]; } return "C";}void test(void){ srand((unsigned int)time(NULL)); int input = 0; do { menu(); printf("/n"); printf("系统提示:请选择:>>>"); scanf_s("%d", &input); printf("/n"); switch (input) { case 1: game(); break; case 0: printf("游戏结束/n"); break; default: printf("非法输入,请重新输入/n"); break; } } while (input);}
**以下就是游戏进行的过程
本人实力有限,游戏体验可能不太好
**
各位有什么优化游戏的建议可以指出
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/122564.html
摘要:三子棋目录一问题介绍三子棋,在民间又叫井字棋。因为人们在游玩时常常不画棋盘的边框,正如汉字中的井字,多称为井字棋。 三子棋 目录 一、问题介绍 三子棋,在民间又叫井字棋。因为人们在游玩时常常不画棋盘的边框,正如汉字中的井字,多称为井字棋。 三子棋的游戏规则十分的简单: ...
摘要:今天博主将为大家带来语言入门级小游戏三子棋井字棋的详细介绍,希望这篇文章对大家能有帮助。在这里,我们使用函数来实现这一功能。 今天博主将为大家带来C语言入门级小游戏——三子棋(井字棋)的详细介绍,希望这篇文章对大家能有帮助 。 在编程的学习过程中,编写一些中这样...
摘要:简单介绍了三子棋原理后接下来为大家讲解分步目标及代码如何实现。电脑下棋我们实现了玩家和电脑的下棋后,我们需要编写一个函数来判断双方的输赢。我们使用函数来实现这一目标。 目录 1.三子棋原理 2.分块代码实现 3.总结 1.首先向大家介绍一下三子棋的原理 首先我们需要有一个棋盘,初始时棋...
阅读 1940·2021-11-22 15:29
阅读 3221·2021-10-14 09:43
阅读 1170·2021-10-08 10:22
阅读 3319·2021-08-30 09:46
阅读 1417·2019-08-30 15:55
阅读 1902·2019-08-30 15:44
阅读 830·2019-08-30 14:19
阅读 1418·2019-08-30 13:13