五子棋(C语言)
2016-05-05 09:24
429 查看
五子棋游戏
五子棋是一种两人对弈的纯策略型棋类游戏,通常双方分别使用黑白两色的棋子,每次一子,轮流下在棋盘直线与横线的交叉点上,先形成 5子连线者 获胜。 棋具与围棋通用。
源程序:
//chess.h
1、开始游戏
2、退出游戏
五子棋是一种两人对弈的纯策略型棋类游戏,通常双方分别使用黑白两色的棋子,每次一子,轮流下在棋盘直线与横线的交叉点上,先形成 5子连线者 获胜。 棋具与围棋通用。
源程序:
//chess.h
#pragma once #include<stdio.h> #define ROW 5 #define COL 5 void Menu(); void Init(char arr[][COL]); void Display(char arr[][COL]); void Player_move(char arr[][COL]); int Computer_move(char arr[][COL]); char Check(char arr[][COL]);//chess.c
#include "chess.h" void Menu() { printf("**************************************************\n"); printf("************* Game: 五子棋 **************\n"); printf("**************************************************\n"); printf("************* 1 开始游戏 **************\n"); printf("************* 0 退出游戏 **************\n"); printf("**************************************************\n"); } void Init(char arr[][COL]) { int i = 0; int j = 0; for (i = 0; i < ROW; i++) { for (j = 0; j < COL; j++) { arr[i][j] = ' '; } } } void Display(char arr[][COL]) { int i = 0; for (i = 0; i < ROW; i++) { printf(" %c | %c | %c | %c | %c \n", arr[i][0], arr[i][1], arr[i][2],arr[i][3],arr[i][4]); if (i != 4) printf("---|---|---|---|--- \n"); } } void Player_move(char arr[][COL]) { int x = 0, y = 0; printf("请输入坐标:(x y)>"); flag: scanf("%d%d", &x, &y); x -= 1; y -= 1; while (arr[x][y] != ' ' || x <0 || x>4 || y <0 || y >4) { printf("坐标选择错误,请重新输入 > "); goto flag; } arr[x][y] = 'X'; } int Computer_move(char arr[][COL]) { int i = 0; int j = 0; for (i = 0; i < ROW; i++) { for (j = 0; j < COL; j++) { if (arr[i][j] == ' ') { break; } } if (arr[i][j] == ' ') break; } if (i*j <= 25) { arr[i][j] = '0'; return 1; } else { printf("平局\n"); return 0; } return 1; } char Check(char arr[][COL]) { int i = 0; for (i = 0; i < ROW; i++) { if (arr[i][0] == arr[i][1] && arr[i][1] == arr[i][2] && arr[i][2] == arr[i][3] && arr[i][3] == arr[i][4]) { return arr[i][0]; } } for (i = 0; i < COL; i++) { if (arr[0][i] == arr[1][i] && arr[1][i] == arr[2][i] && arr[2][i] == arr[3][i] && arr[3][i] == arr[4][i]) { return arr[0][i]; } } if (arr[0][0] == arr[1][1] && arr[1][1] == arr[2][2] && arr[2][2] == arr[3][3] && arr[3][3] == arr[4][4]) { return arr[0][0]; } if (arr[0][4] == arr[1][3] && arr[1][3] == arr[2][2] && arr[2][2] == arr[3][1] && arr[3][1] == arr[4][0]) { return arr[0][4]; } return ' '; }//test.c
#include "chess.h" int main() // 五子棋 { char arr[ROW][COL]; char done = ' '; int ret=0; Flag: Menu(); printf("请选择:"); scanf("%d",&ret); switch(ret) { case 1: Init(arr); do { Display(arr); Player_move(arr); done = Check(arr); if (done != ' ') break; ret = Computer_move(arr); if (ret == 0) { break; } done = Check(arr); } while (done == ' '); Display(arr); if (done == 'X') { printf("^-^ 玩家获胜!^-^\n"); } else if (done == '0') { printf("^-^ 电脑获胜!^-^\n"); } goto Flag; break; case 0: printf("退出游戏!\n"); break; default: printf("Error!\n"); break; }; return 0; }运行结果:
1、开始游戏
2、退出游戏
相关文章推荐
- Linux C函数参考手册(PDF版)
- C# partial关键字说明
- Lua教程(十七):C API简介
- 简单谈谈lua和c的交互
- C#中的委托数据类型简介
- C#编写的艺术字类实例代码
- C#实现打造气泡屏幕保护效果
- 举例讲解C#编程中委托的实例化使用
- 使用C#代码获取存储过程返回值
- C++中explict关键字用法
- C/C++数据对齐详细解析
- 利用C语言来求最大连续子序列乘积的方法
- 字符串的组合算法问题的C语言实现攻略
- C 语言基础教程(我的C之旅开始了)[三]
- 学习C和C++的9点经验总结
- C++中的extern “C”用法详解
- C 语言基础教程(我的C之旅开始了)[七]
- 最大子矩阵问题实例解析
- C字符串操作函数实现方法小结