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不难) 游戏规则 双方各执一 ...
随机推荐
- 全网最适合入门的面向对象编程教程:09 类和对象的Python实现-类之间的关系,你知道多少?
全网最适合入门的面向对象编程教程:09 类和对象的 Python 实现-类之间的关系,你知道多少? 摘要: 本文主要对类之间的关系进行了基本介绍,包括继承.组合.依赖关系,并辅以现实中的例子加以讲解, ...
- 在ubuntu16.04下,源码编译安装特定版本的MongoDB PHP扩展
背景:我的php项目在连接其他mongo库时报:Server at xxx:27017 reports wire version 5, but this version of libmongoc re ...
- Java基础 韩顺平老师的 集合 的部分笔记
498,集合介绍 499,集合体系图(两个图背下) package com.hspedu.collection; import java.util.ArrayList; import java.uti ...
- 前端说你的API接口太慢了,怎么办?
当有千万条海量数据时,前端调取接口发现接口响应的太慢,前端这时让你优化一下接口,你说有几千万条数据,觉得自己尽力了,前端觉得你好菜,别急,读完这篇文章,让前端喊你一声:大佬,厉害!!! 常用的方法总结 ...
- 双指针 & 双向搜索
双指针 根据人类直觉这个东西需要满足单调性,所以预处理的时候大概率需要排序. 好像常与二分结合使用? 可以用在序列.链表(存储位置)或者树.图上(存储结点). 或者用于其他算法(eg:单调队列.差分) ...
- Django 处理http请求之中间件
Django处理http请求之中间件 by:授客 QQ:1033553122 欢迎加入全国软件测试交流QQ群:7156436 测试环境 Win7 Django 1.11 自定义中间件 中间件" ...
- Excel快速下拉填充序列至10000行
问题:想要下拉输入的数据递增得到1.2.3--10000,但是手动下拉太累 解决: 1.如在A1单元格输入1,在A2单元格输入2 2.选中A2单元格,在上方名称框中填写A2:A1000,回车,此时将选 ...
- java面试一日一题:讲下mysql中的锁
问题:请讲下在mysql中的锁 分析:该问题主要考察对中锁的掌握,主要考察的是读.写锁.行锁.间隙锁.next-key,其他还有表锁.意向锁 回答要点: 主要从以下几点去考虑, 1.mysql中的锁有 ...
- fragment的查找和移除
FragmentManager fragmentmanger = getSupportFragmentManager(); FragmentTransaction fragmenttransactio ...
- [春秋云镜] Initial
[春秋云镜] Initial **整套网络环境拓扑:** 一.打进内网 开局一个ip:39.101.184.25,fscan扫一下 存在thinkphp5.0.23的漏洞,可以rce,我们 ...