IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 如何用C语言编写小游戏让你的学习不在无聊——三子棋 -> 正文阅读

[数据结构与算法]如何用C语言编写小游戏让你的学习不在无聊——三子棋

分为三部分入手,更轻松学会。

test.c 测试游戏的逻辑

//测试三子棋的逻辑#include "game.h"void menu(){printf("********************
");printf("****  1.play    ****
");printf("****   0.exit   ****
");printf("********************
");}void game(){char ret = 0;//存放下棋的数据char board[ROW][COL] = { 0 };//初始化棋盘为全空格InitBoard(board, ROW, COL);//打印棋盘DisplayBoard(board, ROW, COL); while (1){//玩家下棋player_move(board, ROW, COL);DisplayBoard(board, ROW, COL);//判断输赢 ret = is_win(board, ROW, COL);if (ret != 'C'){break;}//电脑下棋computer_move(board, ROW, COL);//随机下棋DisplayBoard(board, ROW, COL); ret = is_win(board, ROW, COL);if (ret != 'C'){break;}}if (ret == '*'){printf("玩家赢
");}else if (ret == '#'){printf("电脑赢
");}else if(ret=='Q'){printf("平局
");}//DisplayBoard(board, ROW, COL);} //什么情况下游戏结束//玩家赢-*//电脑赢-#//平局-Q//继续-Cvoid test(){int input = 0;srand((unsigned int)time(NULL));do{menu();printf("请选择:");scanf("%d", &input);switch (input){case 1:game();//游戏break;case 0:printf("退出游戏
");break;default:printf("选择错误
");break;}} while (input);}int main(){test();return 0;}

?

?

game.c 游戏的实现

#include "game.h"void InitBoard(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++){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]);//}//printf("
");//}//}void DisplayBoard(char board[ROW][COL], int row, int col){int i = 0;for (i = 0; i < row; i++){//打印数据//printf(" %c | %c | %c 
",board[i][0],board[i][1],board[i][2]);int j = 0;for (j = 0; j < col; j++){printf(" %c ", board[i][j]);if (j<col-1)printf("|");}printf("
");//打印分割行if (i < row - 1)//printf("---|---|---
");{for (j = 0; j < col; j++){printf("---");if (j < col - 1)printf("|");}printf("
");}}}void player_move(char board[ROW][COL], int row, int col){int x = 0;int y = 0;printf("玩家下棋
");while (1){printf("请输入坐标:");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("该坐标以被占用,请重新输入
");}}else{printf("该坐标以被占用,请重新输入
");}}}void computer_move(char board[ROW][COL], int row, int col){int x = 0;int y = 0;printf("电脑下棋
");while (1){x = rand() % row;//0~2y = rand() % col;//0~2if (board[x][y] == ' '){board[x][y] = '#';break;}}}static int if_full(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++){if (board[i][j] == ' '){return 0;//没满}}}return 1;//满了}char is_win(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 < row; 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];}//判断平局if (if_full(board, row, col) == 1){return 'Q';}//继续return 'C';}

?

game.h 函数声明,符号的定义

#pragma once#include <stdio.h>#include <stdlib.h>#include <time.h>#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 player_move(char board[ROW][COL], int row, int col);//电脑下棋void computer_move(char board[ROW][COL], int row, int col);//判断输赢char is_win(char board[ROW][COL], int row, int col);

?

?

?

?

?

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-01-25 10:49:54  更:2022-01-25 10:50:58 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 19:47:04-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码