C语言迷宫

目录

开头

大家好,我叫这是我58。今天,我要来看我用C语言编译出来的迷宫游戏。

程序

c 复制代码
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <Windows.h>
void printmaze(char strmaze[9][9]) {
	int ia = 0;
	int ib = 0;
	for (ia = 0; ia < 9; ia++) {
		for (ib = 0; ib < 9; ib++) {
			printf("%c", strmaze[ia][ib]);
		}
		printf("|\n");
	}
	printf("---------@\n");
}
int main() {
	int i = 0;
	char ch = 0;
	char strmaze[9][9] = {
		"P *      ",
		"*  *  *  ",
		" *     **",
		"*   *    ",
		"  *  * * ",
		" * * *   ",
		"  * * ** ",
		" *   * **",
		"   *    G"
	};
	char* cp = &strmaze[0][0];
	printf("欢迎你来玩这个迷宫游戏,在这个迷宫中,"P"是你,"G"是终点,而"*"是墙,空格是你可以走的地方,"w"往上,"a"往左,"s"往下,"d"往右,而你只要走到终点就可以了,这就是这个迷宫游戏的规则");
	Sleep(4500);
	system("cls");
	while ('G' == strmaze[8][8]) {
		printmaze(strmaze);
		scanf("%c", &ch);
		while ('\n' != getchar()) {
			;
		}
		*cp = ' ';
		switch (ch) {
		case 'w':
			for (i = 0; i < 9; i++) {
				if (cp == &strmaze[0][i]) {
					break;
				}
			}
			(9 == i && '*' != *(cp - 9)) && (cp -= 9);
			break;
		case 'a':
			for (i = 0; i < 9; i++) {
				if (cp == &strmaze[i][0]) {
					break;
				}
			}
			(9 == i && '*' != *(cp - 1)) && cp--;
			break;
		case 's':
			for (i = 0; i < 9; i++) {
				if (cp == &strmaze[8][i]) {
					break;
				}
			}
			(9 == i && '*' != *(cp + 9)) && (cp += 9);
			break;
		case 'd':
			for (i = 0; i < 9; i++) {
				if (cp == &strmaze[i][8]) {
					break;
				}
			}
			(9 == i && '*' != *(cp + 1)) && cp++;
			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 把有9行9列的二维字符数组strmaze初始化为下面的图片


等待4.5秒,等待好后就清屏 是 是 否 是 是 是(break) 是 break 清屏 否 否 是 是 是(break) 是 break 否 是 是(break) 是 break 否 是 是 是(break) 是 break 否(break) 否 否 否(break) 否 否 否(break) 否 否 否(break) 否 否 否(break) 输出"欢迎你来玩这个迷宫游戏,在这个迷宫中,"P"是你,"G"是终点,而"*"是墙,空格是你可以走的地方,"w"往上,"a"往左,"s"往下,"d"往右,而你只要走到终点就可以了,这就是这个迷宫游戏的规则" 'G' == strmaze[8][8]? 把ch设为你输入的字符 '\n' != getchar()? 把解引用的pc设为空格 'w' == ch? 设i为0 i < 9? cp == &strmaze[0][i]? 9 == i && '*' != *(cp - 9)? cp向左移动9位 把解引用的cp设为"P" 把窗口的背景色设为黑色,前景色设为淡绿色 输出"恭喜你,你赢了\n" 结束 'a' == ch? 设i为0 i < 9? cp == &strmaze[i][0]? 9 == i && '*' != *(cp - 1)? cp向左移动一位 's' == ch? 设i为0 i < 9? cp == &strmaze[8][i]? 9 == i && '*' != *(cp + 9)? cp向右移动9位 'd' == ch? 设i为0 i < 9? cp == &strmaze[i][8]? 9 == i && '*' != *(cp + 1)? cp向右移动一位 i自增1 i自增1 i自增1 i自增1
printmaze函数 是 是 否 否 结束 开始 定义整型ia为0 定义整型ib为0 设ia为0 ia < 9? 设ib为0 ia < 9? 输出"%c"("%c"代二维字符数组strmaze的第ia行的第ib项) ib自增1 输出"|\n" ia自增1 输出"---------@\n"

程序输入与输出的效果

迷宫

结尾

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

相关推荐
凤年徐7 分钟前
【C/C++】深入理解指针(二)
c语言·开发语言·c++·经验分享·笔记·指针
Cao12345678932140 分钟前
扫雷-C语言版
c语言·开发语言
GZX墨痕2 小时前
从零学习直接插入排序
c语言·数据结构·排序算法
Susea&2 小时前
数据结构初阶:双向链表
c语言·开发语言·数据结构
Net_Walke2 小时前
【C数据结构】 TAILQ双向有尾链表的详解
c语言·数据结构·链表
TDengine (老段)2 小时前
TDengine 语言连接器(Node.js)
大数据·c语言·数据库·物联网·node.js·时序数据库·tdengine
长流小哥4 小时前
Linux网络编程实战:从字节序到UDP协议栈的深度解析与开发指南
linux·c语言·开发语言·网络·udp
幼儿园园霸柒柒4 小时前
第七章:7.2求方程a*x*x+b*x+c=0的根,用3个函数,分别求当:b*b-4*a*c大于0、等于0和小于0时的根并输出结果。从主函数输入a、b、c的值
c语言·开发语言·算法·c#
不知道叫什么呀4 小时前
【C语言基础】C++ 中的 `vector` 及其 C 语言实现详解
c语言·开发语言·c++
boonya5 小时前
开发一款游戏需要哪些岗位角色参与?
游戏·游戏行业·岗位设置·协作配合