C语言穿墙迷宫

开头

大家好,我叫这是我58

程序

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <Windows.h>
void printmaze(const char strmaze[11][11], const int iwalk) {
	int ia = 0;
	int ib = 0;
	for (ia = 0; ia < 11; ia++) {
		for (ib = 0; ib < 11; ib++) {
			printf("\033[%sm%c\033[0m", 'G' == strmaze[ia][ib] ? "32;1" : "0", strmaze[ia][ib]);
		}
		printf("|\n");
	}
	printf("-----------@\n你走了%d步\n", iwalk);
}
int main() {
	srand((unsigned int)time(NULL));
	int i = 0;
	int iw = 0;
	int iwalk = 0;
	char ch = 0;
	char strmaze[11][11] = {
		'*','*','*','*','*','*','*','*','*','*','G',
		'*','*','*','*','*','*','*','*','*','*','*',
		'*','*','*','*','*','*','*','*','*','*','*',
		'*','*','*','*','*','*','*','*','*','*','*',
		'*','*','*','*','*','*','*','*','*','*','*',
		'*','*','*','*','*','*','*','*','*','*','*',
		'*','*','*','*','*','*','*','*','*','*','*',
		'*','*','*','*','*','*','*','*','*','*','*',
		'*','*','*','*','*','*','*','*','*','*','*',
		'*','*','*','*','*','*','*','*','*','*','*',
		'P','*','*','*','*','*','*','*','*','*','*'
	};
	int wallarr[11][11] = { 0 };
	wallarr[0][10] = 2;
	wallarr[10][0] = 2;
	char* cp = &strmaze[10][0];
	printf("欢迎你来玩穿墙迷宫,在这个迷宫中,“P”是你,空格是你可以走的地方,“\033[32;1mG\033[0m”为\033[32;1m终点\033[0m,有些“*”是假墙,你可以走,有些“*”是真墙,你撞上去的话就会改变整个迷宫里所有墙的真假性了,而你只要走到\033[32;1m终点\033[0m,就可以\033[32;1m赢\033[0m了,你听懂了吗?");
	Sleep(6400);
	system("cls");
	for (i = 0; i < 121; i++) {
		2 != wallarr[0][i] && (wallarr[0][i] = rand() % 2);
	}//墙之初始化
	while ('G' == strmaze[0][10]) {
		int ip = cp - &strmaze[0][0];
		for (i = 0; i < 121; i++) {
			2 != wallarr[0][i] && i != ip && (strmaze[0][i] = '*');
		}//设墙
		printmaze(strmaze, iwalk);
		scanf("%c", &ch);
		while ('\n' != getchar()) {
			;
		}
		*cp = ' ';
		switch (ch) {
		case 'w':
			for (i = 0; i < 11; i++) {
				if (cp == &strmaze[0][i]) {
					break;
				}
			}
		    11 == i && 1 == wallarr[0][ip - 11] && (iw = 1), 11 == i && (!(wallarr[0][ip - 11]) || 2 == wallarr[0][ip - 11]) && (cp -= 11);
			iwalk++;
			break;
		case 'a':
			for (i = 0; i < 11; i++) {
				if (cp == &strmaze[i][0]) {
					break;
				}
			}
			11 == i && 1 == wallarr[0][ip - 1] && (iw = 1), 11 == i && (!(wallarr[0][ip - 1]) || 2 == wallarr[0][ip - 1]) && (cp--);
			iwalk++;
			break;
		case 's':
			for (i = 0; i < 11; i++) {
				if (cp == &strmaze[10][i]) {
					break;
				}
			}
			11 == i && 1 == wallarr[0][ip + 11] && (iw = 1), 11 == i && (!(wallarr[0][ip + 11]) || 2 == wallarr[0][ip + 11]) && (cp += 11);
			iwalk++;
			break;
		case 'd':
			for (i = 0; i < 11; i++) {
				if (cp == &strmaze[i][10]) {
					break;
				}
			}
			11 == i && 1 == wallarr[0][ip + 1] && (iw = 1), 11 == i && (!(wallarr[0][ip + 1]) || 2 == wallarr[0][ip + 1]) && (cp++);
			iwalk++;
			break;
		default:
			break;
		}
		if (iw) {
			for (i = 0; i < 121; i++) {
				2 != wallarr[0][i] && ip != i && (wallarr[0][i] = rand() % 2);
			}
		}//走后撞墙? --> (-是->改变墙的属性)
		iw = 0;
		*cp = 'P';
		system("cls");
	}
	system("color 0A");
	printf("恭喜你,你一共走了%d步就到达了终点\n", iwalk);
	return 0;
}//穿墙迷宫: 走后撞墙? --> (-是->改变墙的属性) 设墙

程序的流程图

开始
把宏_CRT_SECURE_NO_WARNINGS定义为1
导入stdio.h
导入stdlib.h
导入time.h
导入Windows.h
定义printmaze函数
把随机数的种子设为现在的时间戳
定义整型i为0
定义整型iw为0
定义整型iwalk为0
定义字符ch为0
把有11行11列的二维字符数组strmaze初始化为下面的图片

走后撞墙? --> (-是->改变墙的属性)
设墙
墙之初始化
等待6.4秒,等待好后就清屏
是(break)
break
清屏
是(break)
break
是(break)
break
break
iw?
设i为0
i < 121?
2 != wallarr[0][i] && ip != i?
把二维整型数组wallarr第0行第i列的元素设为随机数模2的结果
i自增1
设i为0
i < 121?
2 != wallarr[0][i] && i != ip?
把二维字符数组strmaze第0行第i列的元素设为字符“*”
i自增1
设i为0
i < 121?
2 != wallarr[0][i]?
把二维整型数组wallarr第0行第i列的元素设为随机数模2的结果
i自增1
把有11行11列的二维整型数组wallarr里的元素全都初始化为0
把二维整型数组wallarr第0行第10列的元素设为2
把二维整型数组wallarr第10行第0列的元素也设为2
定义字符指针cp为二维字符数组strmaze第10行第0列的地址
输出“欢迎你来玩穿墙迷宫,在这个迷宫中,“P”是你,空格是你可以走的地方,“\​033[32;1mG\​033[0m”为\​033[32;1m终点\​033[0m,有些“*”是假墙,你可以走,有些“*”是真墙,你撞上去的话就会改变整个迷宫里所有墙的真假性了,而你只要走到\​033[32;1m终点\​033[0m,就可以\​033[32;1m赢\​033[0m了,你听懂了吗?”
'G' == strmaze[0][10]?
定义整型ip为cp与二维字符数组strmaze第0行第0列的地址之间的元素个数
执行printmaze函数,参数有二维字符数组strmaze和整型iwalk
把ch设为你输入的字符
'\​n' != getchar()?
把解引用的cp设为空格
'w' == ch?
设i为0
i < 11?
cp == &strmaze[0][i]?
11 == i && 1 == wallarr[0][ip - 11]?
把iw设为1
11 == i && (!(wallarr[0][ip - 11]) || 2 == wallarr[0][ip - 11])?
把cp向左移动11位
iwalk自增1
设iw为0
把解引用的cp设为字符“P”
把窗口的背景色设为黑色,前景色设为淡绿色
输出“恭喜你,你一共走了%d步就到达了终点\​n”(“%d”代iwalk)
结束
'a' == ch?
设i为0
i < 11?
cp == &strmaze[i][0]?
11 == i && 1 == wallarr[0][ip - 1]?
把iw设为1
11 == i && (!(wallarr[0][ip - 1]) || 2 == wallarr[0][ip - 1])?
把cp向左移动一位
iwalk自增1
's' == ch?
设i为0
i < 11?
cp == &strmaze[10][i]?
11 == i && 1 == wallarr[0][ip + 11]?
设iw为1
11 == i && (!(wallarr[0][ip + 1])?
把cp向右移动11位
iwalk自增1
'd' == ch?
设i为0
i < 11?
cp == &strmaze[i][10]?
11 == i && 1 == wallarr[0][ip + 1]?
设iw为1
11 == i && (!(wallarr[0][ip + 1]) || 2 == wallarr[0][ip + 1])?
把cp向右移动一位
iwalk自增1
i自增1
i自增1
i自增1
i自增1
穿墙迷宫: 走后撞墙? --> (-是->改变墙的属性) 设墙
printmaze函数
结束
开始
定义整型ia为0
定义整型ib为0
设ia为0
ia < 11?
设ib为0
ib < 11?
输出“\​033[%sm%c\​033[0m”(如果字符“G”为二维字符数组strmaze的第ia行第ib列的元素,那么“%s”代“32;1”,否则“%s”代“0”,“%c”则代二维字符数组strmaze的第ia行第ib列的元素)
ib自增1
输出“|\​n”
ia自增1
输出“-----------@\​n你走了%d步\​n”(“%d”代iwalk)

程序游玩的效果

穿墙迷宫

下一篇博客要说的东西

阴阳迷宫

  • 14
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值