C语言三子棋
话说自从大一学C语言后用C语言的巅峰也就是第十二届蓝桥杯了,后续开发什么的都是用的java,搞开发java这样的面向对象语言确实用着更顺手方便点。不过C语言YYDS,“C生万物”嘛,哈哈。
本文Author:愷龍
现在准备考研了,需要考查很多C语言的东西,又开始了重温C语言和复习,在复习了一遍语法后搞个小东西,玩玩就整了三子棋,虽说是三子棋,但是头文件那里改成5,然后游戏输赢的判断语句加两行就成五子棋了,游戏的逻辑是玩家和电脑下棋,所谓的电脑其实就是随机数,挺简单的代码实现。
先看效果:

代码组成:

//test.c 测试游戏的逻辑
//game.h关于游戏相关的函数声明,符号声明头文件的包含
//game.c 游戏相关函数的实现
所有代码文件:
test.c
点击查看代码
#include "game.h"
void menu(){
printf("*************************\n");
printf("**** 1.play **********\n");
printf("**** 0.exit **********\n");
printf("*************************\n");
}
void game(){
//存储数据---二维数组
char board[ROW][COL];
//初始化棋盘 -- 初始化空格
initBoard(board,ROW,COL);
//打印棋盘 本质是打印数组内容
displayBoard(board,ROW,COL);
char ret = 0;//接收游戏状态
while(1){
//玩家走
playMove(board,ROW,COL);
displayBoard(board,ROW,COL);
//判断玩家是否赢得游戏
ret = isWin(board,ROW,COL);
if(ret != 'C'){
break;
}
//电脑走
computerMove(board,ROW,COL);
displayBoard(board,ROW,COL);
//判断电脑是否赢得游戏
ret = isWin(board,ROW,COL);
if(ret != 'C'){
break;
}
}
if(ret == '*'){
printf("玩家赢了\n");
}else if(ret == '#'){
printf("电脑赢了\n");
}else{
printf("平局\n");
}
displayBoard(board,ROW,COL);
}
int main(){
int input = 0;
srand((unsigned int)time(NULL));
do{
menu();
printf("请选择:>");
scanf("%d",&input);
switch(input){
case 1:
game();
break;
case 0:
printf("退出游戏!\n");
break;
default:
printf("选择错误,重新选择!\n");
break;
}
}while(input);
return 0;
}
game.h
点击查看代码
//头文件
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
//符号的定义
#define ROW 3
#define COL 3
//函数的声明
//初始化棋盘
void initBiard(char board[ROW][COL],int row,int col);
//打印棋盘的函数
void displayBoard(char board[ROW][COL],int row,int col);
//玩家下棋
void playMove(char board[ROW][COL],int row,int col);
//电脑下棋
void computerMove(char board[][COL],int row,int col);
//判断游戏结果
//1. 玩家赢了 -- *
//2. 电脑赢了 -- #
//3. 平局 -- Q
//4. 游戏继续 -- C
char isWin(char board[ROW][COL],int row,int col);
game.c
点击查看代码
#include "game.h"
//初始化棋盘
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] = ' ';
}
}
}
//展示棋盘
void displayBoard(char board[ROW][COL],int row,int col){
int i = 0;
for(i = 0;i < row;i++){
int j = 0;
for(j = 0;j < col;j++){
printf(" %c ",board[i][j]);
if(j < col -1)
printf("|");
}
printf("\n");
if(i < row -1){
int j = 0;
for(j = 0;j< col;j++){
printf("---");
if(j < col -1)
printf("|");
}
printf("\n");
}
}
}
//玩家走
void playMove(char board[][COL],int row,int col){
int x = 0;
int y = 0;
printf("玩家走>\n");
while(1){
printf("请输入下棋的坐标:>\n");
scanf("%d %d",&x,&y);
//判断坐标合法性
if(x >= 1 && x <= row && y>= 1 && y<= col){
//下棋
//判断坐标是否被占用
if(board[x-1][y-1] == ' '){
board[x-1][y-1] = '*';
break;
}else{
printf("坐标被占用,请重新输入\n");
}
}else{
printf("坐标非法,请重新输入\n");
}
}
}
//电脑走
void computerMove(char board[][COL],int row,int col){
printf("电脑走\n");
while(1){
int x = rand() % ROW;
int y = rand() % COL;
//判断位置是否被占用
if(board[x][y] == ' '){
board[x][y] = '#';
break;
}
}
}
//判断棋盘是否满了
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;//棋盘满了
}
//判断游戏结果
char isWin(char board[ROW][COL],int row,int col){
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< col;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[0][2] == board[1][1] && board[1][1] == board[2][0] && board[1][1] != ' '){
return board[1][1];
}
//判断平局
//棋盘满返回1不满返回0
int ret = isFull(board,row,col);
if(ret == 1){
return 'Q';
}
//继续
return 'C';
}
欢迎关注公众号:“愚生浅末”。
本文Author:愷龍
C语言三子棋的更多相关文章
- C语言-三子棋项目
开源地址 https://kxd.lanzoul.com/iLwHG0e4nupc 肯定有大量BUG 求指出 电脑自动下棋的算法很差 毕竟我也没特意去研究
- C语言数组实现三子棋
C语言实现三子棋(通过数组) 需要包含的头文件 #include <stdio.h> #include <stdlib.h> #include <time.h> 创 ...
- c语言实现:三子棋
问题描述:两个游戏者在3*3棋盘里轮流作标记,如果一个人在行,列或者两个对角线可以作三个标记,则为获胜. 我们首先得打印菜单供玩家选择(可以选择玩游戏或者退出游戏) void menu() { pri ...
- 用c语言实现三子棋
1 game.c://实现三子棋的.c文件 #define _CRT_SECURE_NO_WARNINGS #include"game.h" void init_board(cha ...
- C语言简易三子棋
这是本人依据现学知识写的简易三子棋,也不是那么简洁明了,望大佬指点 #define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include&l ...
- c语言小游戏-三子棋的完成
三子棋的实现 一.实现思路 1.初始化数组 三子棋是九宫格的格式,所以用二维数组接收数据.用‘O’代表电脑下的子,‘X’代表玩家下的子.未下子的时候初始化 ’ ‘(space).则二维数组为“char ...
- 51Nod:1995 三子棋
1995 三子棋 题目来源: syu校赛 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注 小的时候大家一定玩过"井"字棋吧.也就是在 ...
- 51nod 1995 三子棋
小的时候大家一定玩过“井”字棋吧.也就是在九宫格中,只要任意行.列,或者任意连续对角线上面出现三个相同的,就能获胜.现在小明和小花也在玩三子棋,但是他们不是在九宫格里,而是在3×4的格子里面.现在小明 ...
- P1838 三子棋I
题目描述 小a和uim喜欢互相切磋三子棋.三子棋大家都玩过是吗?就是在九宫格里面OOXX(别想歪了),谁连成3个就赢了. 由于小a比较愚蠢,uim总是让他先. 我们用9个数字表示棋盘位置: 123 4 ...
- React + Ts 实现三子棋小游戏
在这里阅读效果更佳 还记得当年和同桌在草稿纸上下三子棋的时光吗 今天我们就用代码来重温一下年少(假设你有react基础,没有也行,只要你会三大框架的任意一种,上手react不难) 游戏规则 双方各执一 ...
随机推荐
- 一款EF Core下高性能、轻量级针对分表分库读写分离的解决方案
前言 今天大姚给大家分享一款EF Core下高性能.轻量级针对分表分库读写分离的解决方案,开源(Apache License)的EF Core拓展程序包:ShardingCore. ShardingC ...
- 使用Terminal.Gui构建功能强大的.NET控制台应用
前言 前段时间分享了一个库帮你轻松的创建漂亮的.NET控制台应用程序 - Spectre.Console的文章教程,然后就有小伙伴提问:.NET控制台应用需要应对强交互性的场景,有什么好的解决方案?, ...
- Nginx常用操作
Nginx Nginx的最重要的几个使用场景 静态资源服务,通过本地文件提供服务 反向代理服务,延伸出包括缓存,负载均衡等 API服务,OpenResty 相关概念 简单请求和非简单请求 请求方法是H ...
- SpringBoot结合easyexcel处理Excel文件
文/朱季谦 假如有这样一个需求,每天需要读取以下表头的Excel文件,统计文件里击中黑名单的比例,该文件is_blacklist列的1表示击中了黑名单,0表示未击中黑名单. 基于该需求,可以在定时任务 ...
- [oeasy]教您玩转python - 0003 - 编写 py 文件
编写 py 文件 回忆上次内容 次在解释器里玩耍 了解到字符串就是给一堆字符两边加引号 可以是单引号 也可以是双引号 这样游乐场就知道 这个不是一个名字 而是一个字符串 字符串可以用print函数 ...
- Day 8 - 并查集、堆、set 与 map
并查集 引入 并查集是一种用于管理元素所属集合的数据结构,实现为一个森林,其中每棵树表示一个集合,树中的节点表示对应集合中的元素. 顾名思义,并查集支持两种操作: 合并(\(\text{Union}\ ...
- 《HelloGitHub》第 100 期
兴趣是最好的老师,HelloGitHub 让你对编程感兴趣! 简介 HelloGitHub 分享 GitHub 上有趣.入门级的开源项目. github.com/521xueweihan/HelloG ...
- 《最新出炉》系列入门篇-Python+Playwright自动化测试-54- 上传文件(input控件) - 上篇
1.简介 在实际工作中,我们进行web自动化的时候,文件上传是很常见的操作,例如上传用户头像,上传身份证信息等.所以宏哥打算按上传文件的分类对其进行一下讲解和分享. 2.上传文件的API(input控 ...
- 【MySQL】拆分经纬度字段
数据结构: 表中一字段存储经度和纬度: +---------------------------+ | INSTALL_LOLA_NUM | +---------------------------+ ...
- 【ActiveJdbc】04
一.乐观锁 作者po的乐观锁思想: http://en.wikipedia.org/wiki/Optimistic_concurrency_control 维基百科,墙了看不到 作者要求表字段必须存在 ...