C语言边界互通传送迷宫

server/2024/9/23 3:18:00/

目录

  • 注意事项
  • 开头
  • 程序
  • 程序的流程图
  • 程序输入与输出的效果
  • 结尾

注意事项

  • 程序里有关字符’\033’的输出都关于Sunshine-Linux的其中一篇博客——《printf函数高级用法设置打印字体颜色和背景色等》

开头

大家好,我叫这是我58。今天,我们来看一下我用C语言编译的边界互通传送迷宫和与之相关的一些东西。

程序

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <Windows.h>
void printmaze(const char strmaze[9][9]) {int ia = 0;int ib = 0;for (ia = 0; ia < 9; ia++) {for (ib = 0; ib < 9; ib++) {printf("\033[%sm%c", 'G' == strmaze[ia][ib] ? "32" : '^' == strmaze[ia][ib] ? "33" : "0", strmaze[ia][ib]);}printf("\033[0m|\n");}printf("---------@\n");
}
int main() {int i = 0;char ch = 0;char strmaze[9][9] = {" *  ^^ ^ ","*P*^ ^  ^","^*^    ^ "," ^ ^^^ ^ ","      ^  ","   ^ ^^ ^","^^ ^    ^","    ^  G "," ^  ^  * "};char* cp = &strmaze[1][1];char* const carrp[32] = { &strmaze[0][4],&strmaze[0][5],&strmaze[0][7],&strmaze[1][3],&strmaze[1][5],&strmaze[1][8],&strmaze[2][0],&strmaze[2][7],&strmaze[3][3],&strmaze[3][4],&strmaze[3][7], &strmaze[4][6],&strmaze[6][0],&strmaze[3][1],&strmaze[5][6],&strmaze[6][3],&strmaze[7][4],&strmaze[2][2],&strmaze[3][5],&strmaze[6][1],&strmaze[6][8],&strmaze[5][8],&strmaze[5][5],&strmaze[5][3],&strmaze[8][4],&strmaze[8][1],&strmaze[0][1],&strmaze[1][0],&strmaze[1][2],&strmaze[2][1],&strmaze[8][7],&strmaze[1][1] };printf("欢迎你来玩这个迷宫游戏,在这个迷宫中,“P”是你,“G”是终点,而“*”是你可以走的地方,空格是虚空,你不能走,“w”往上,“a”往左,“s”往下,“d”往右,并且,这个迷宫边界互通,而且只要在传送点“^”上输入“z”,就可以传送到这个传送点的另一端,而你只要走到终点就可以了,这就是这个迷宫游戏的规则");Sleep(8800);system("cls");while ('G' == strmaze[7][7]) {printmaze(strmaze);scanf("%c", &ch);while ('\n' != getchar()) {;}*cp = ' ';for (i = 0; i < 26; i++) {' ' == *carrp[i] && (*carrp[i] = '^');}for (; i < 32; i++) {' ' == *carrp[i] && (*carrp[i] = '*');}switch (ch) {case 'w':for (i = 0; i < 9; i++) {if (cp == &strmaze[0][i]) {break;}}(9 == i && ' ' != *(cp - 9)) && (cp -= 9);(9 != i && ' ' != *(cp + 72)) && (cp += 72);break;case 'a':for (i = 0; i < 9; i++) {if (cp == &strmaze[i][0]) {break;}}(9 == i && ' ' != *(cp - 1)) && cp--;(9 != i && ' ' != *(cp + 8)) && (cp += 8);break;case 's':for (i = 0; i < 9; i++) {if (cp == &strmaze[8][i]) {break;}}(9 == i && ' ' != *(cp + 9)) && (cp += 9);(9 != i && ' ' != *(cp - 72)) && (cp -= 72);break;case 'd':for (i = 0; i < 9; i++) {if (cp == &strmaze[i][8]) {break;}}(9 == i && ' ' != *(cp + 1)) && (cp++);(9 != i && ' ' != *(cp - 8)) && (cp -= 8);break;case 'z':for (i = 0; i < 26; i++) {if (carrp[i] == cp) {i < 13 && (cp = carrp[i + 13]), i < 13 || (cp = carrp[i - 13]);break;}}break;default:break;}*cp = 'P';system("cls");}system("color 0A");printf("恭喜你,你赢了\n");return 0;
}

程序的流程图

开始
把宏_CRT_SECURE_NO_WARNINGS定义为1
导入stdio.h
导入Windows.h
定义printmaze函数
定义型i为0
定义字符ch为0
定义二维字符数组strmaze为下面的图片

等待8.8秒,等待好后就清屏
是(break)
break
清屏
是(break)
break
是(break)
break
是(break)
break
否(break)
否(break)
否(break)
否(break)
否(break)
否(break)
定义字符指针cp为二维字符数组strmaze第一行第一列的元素的地址
把有32个字符指针的常量数组carrp分别初始化为第0行第4列的地址,第0行第5列的地址,第0行第7列的地址,第1行第3列的地址,第1行第5列的地址,第1行第8列的地址,第2行第0列的地址,第2行第7列的地址,第3行第3列的地址,第3行第4列的地址,第3行第7列的地址,第4行第6列的地址,第6行第0列的地址,第3行第1列的地址,第5行第6列的地址,第6行第3列的地址,第7行第4列的地址,第2行第2列的地址,第3行第5列的地址,第6行第1列的地址,第6行第8列的地址,第5行第8列的地址,第5行第5列的地址,第5行第3列的地址,第8行第4列的地址,第8行第1列的地址,第0行第1列的地址,第1行第0列的地址,第1行第2列的地址,第2行第1列的地址,第8行第7列的地址和第1行第1列的地址
输出“欢迎你来玩这个迷宫游戏,在这个迷宫中,“P”是你,“G”是终点,而“*”是你可以走的地方,空格是虚空,你不能走,“w”往上,“a”往左,“s”往下,“d”往右,并且,这个迷宫边界互通,而且只要在传送点“^”上输入“z”,就可以传送到这个传送点的另一端,而你只要走到终点就可以了,这就是这个迷宫游戏的规则”
'G' == strmaze[7][7]?
把字符ch设为你输入的字符
'\n' != getchar()?
把解引用的的cp设为空格
设i为0
i < 26?
' ' == *carrp[i]?
把解引用的字符指针常量数组carrp的第i项设为“^”
i自增1
i < 32?
' ' == *carrp[i]?
把解引用的字符指针常量数组carrp的第i项设为“*”
i自增1
'w' == ch?
设i为0
i < 9?
cp == &strmaze[0][i]?
9 == i && ' ' != *(cp - 9)?
把cp向左移动9位
9 != i && ' ' != *(cp + 72)?
把cp向右移动72位
把解引用的cp设为“P”
把窗口的背景色设为黑色,前景色设为淡绿色
输出“恭喜你,你赢了\n”
结束
'a' == ch?
设i为0
i < 9?
cp == &strmaze[i][0]?
9 == i && ' ' != *(cp - 1)?
把cp向左移动一位
9 != i && ' ' != *(cp + 8)?
cp向右移动8位
's' == ch?
设i为0
i < 9?
cp == &strmaze[8][i]?
9 == i && ' ' != *(cp + 9)?
把cp向右移动9位
9 != i && ' ' != *(cp - 72)?
把cp向左移动72位
'd' == ch?
设i为0
i < 9?
cp == &strmaze[i][8]?
9 == i && ' ' != *(cp + 1)?
把cp向右移动一位
9 != i && ' ' != *(cp - 8)?
把cp向左移动8位
'z' == ch?
设i为0
i < 26?
carrp[i] == cp?
i < 13?
把cp设为字符指针常量数组carrp的第i加13项
i < 13?
break
i自增1
i自增1
i自增1
i自增1
i自增1
把cp设为字符指针常量数组carrp的第i减13项
printmaze函数
结束
开始
定义整型ia为0
定义整型ib为0
设ia为0
ia < 9?
设ib为0
ib < 9?
输出“\​033[%sm%c”(如果有9行9列的常量二维数组strmaze的第ia行第ib列为“G”,那么就代“32”,否则如果有9行9列的常量二维数组strmaze的第ia行第ib列为“^”,那么就代“33”,否则就代“0”,“%c”则代有9行9列的常量二维数组strmaze的第ia行第ib列的字符)
ib自增1
输出“\​033[0m|\​n”
ia自增1
输出“---------@\​n”

程序输入与输出的效果

结尾

在你看到这里后,可以评论来互动一下我哦。


http://www.ppmy.cn/server/90625.html

相关文章

【Vulnhub系列】Vulnhub_Raven2靶场渗透(原创)

【Vulnhub系列靶场】Vulnhub_Raven2 渗透 原文转载已经过授权 原文链接&#xff1a;Lusen的小窝 - 学无止尽&#xff0c;不进则退 (lusensec.github.io) 一、环境准备 从网盘下载该靶机&#xff0c;在vm中选择【打开】 然后设置好存储路径&#xff0c;开机后检查靶机的网络连…

sqlalchemy获取数据模型类所有字段

sqlalchemy获取数据模型类所有字段 在 SQLAlchemy 中,要获取数据模型类(即声明模型类)的所有字段,可以通过以下方式进行: 使用 __table__ 属性: SQLAlchemy 的每个模型类都有一个 __table__ 属性,它表示与该模型类关联的数据库表。通过这个属性,可以获取表的所有列信息…

【基于PSINS】UKF/SSUKF对比的MATLAB程序

UKF与SSUKF UKF是&#xff1a;无迹卡尔滤波 SSUKF是&#xff1a;简化超球面无迹卡尔曼滤波 UKF 相较于传统的KF算法&#xff0c;UKF能够更好地处理非线性系统&#xff0c;并且具有更高的估计精度。它适用于多种应用场景&#xff0c;如机器人定位导航、目标跟踪、信号处理等。…

eclipse修改tomcat的Jre运行环境

1.双击tomcat 2.RuntimeEnvironment 3.选择

使用GoAccess进行Web日志可视化

运行网站的挑战之一是了解您的 Web 服务器正在做什么。虽然各种监控应用程序可以在您的服务器以高负载或页面响应缓慢运行时提醒您&#xff0c;但要完全了解正在发生的事情&#xff0c;唯一的方法是查看 Web 日志。阅读日志数据页面并了解正在发生的事情可能需要花费大量时间。…

ElasticSearch的应用场景和优势

ElasticSearch是一个开源的分布式搜索和分析引擎&#xff0c;它以其高性能、可扩展性和实时性在多个领域得到了广泛应用。以下是ElasticSearch的主要应用场景和优势&#xff1a; 应用场景 实时搜索&#xff1a; ElasticSearch以其快速、可扩展和实时的特性&#xff0c;成为实…

MySQL的存储过程

MySQL的存储过程 存储过程的概念 完成特定功能的sql语句的集合。把定义好的sql集合在一个特定的sql函数中每次执行调用函数即可。还可以实现传参的调用。 存储过程的作用 执行速度比sql语句执行的速度更快&#xff0c;执行的效率也更高。 客户端可以随时调用发放&#xff…

布隆过滤器面试三道题

针对布隆过滤器的面试题&#xff0c;我将从简单到困难给出三道题目&#xff0c;并附上每道题的简要解析和参考答案。 1. 简单题&#xff1a;什么是布隆过滤器&#xff1f;请简述其基本原理。 解析&#xff1a; 这道题是布隆过滤器的基础概念题&#xff0c;主要考察面试者对布…