随机步问题

news2024/10/5 22:22:35

随机步问题

  • 1.题目简介
  • 2.题目分析
  • 3.创建变量
  • 4.主程序
  • 5.程序效果
  • 6.程序可以改进的点

1.题目简介

在这里插入图片描述

2.题目分析

数组初始化
生成随机方向
判断程序结束的标志
当前元素为Z,或者四个方向都堵住了

3.创建变量

arry[ROW][COL]创建二维数组
_Bool a,b,c,d判断是否会出现四个方向都被堵住的情况
char ch对字符数组赋值,且可以自增方便对下一个元素赋值

4.主程序

#include<stdio.h>
#include<time.h>
#include<stdlib.h>
#define ROW 10
#define COL 10
int main()
{
	int i, j, dir;
	_Bool a = false, b = false, c = false, d = false;
	char arry[ROW][COL], ch = 'A';
	srand((unsigned int)time(NULL));
	for (i = 0; i < ROW; i++)
	{
		for (j = 0; j < COL; j++)
		{
			arry[i][j] = '.';
		}
	}
	arry[0][0] = ch;//游戏开始的地方
	i = 0; j = 0;
	for (;;)
	{
		dir = rand() % 4;//规定0为向上,1为向下,2为向左,3为向右
		switch (dir)
		{
		case 0:
			if ((i > 0) && (arry[i - 1][j] == '.'))
			{
				arry[--i][j] = ++ch;//赋值
				a = false;//该方向通过时,将所有变量置为false
				b = false;
				c = false;
				d = false;
				break;
			}
			else
			{
				a = true;//方向不通过,将一个方向的变量置为true
				break;
			}
		case 1:
			if ((i < 9) && (arry[i + 1][j] == '.'))//防止越界且该元素未赋值
			{
				arry[++i][j] = ++ch;
				a = false;
				b = false;
				c = false;
				d = false;
				break;
			}
			else
			{
				b = true;
				break;
			}
		case 2:
			if ((j > 0) && (arry[i][j - 1] == '.'))

			{
				arry[i][--j] = ++ch;
				a = false;
				b = false;
				c = false;
				d = false;
				break;
			}
			else
			{
				c = true;
				break;
			}
		case 3:
			if ((j < 9) && (arry[i][j + 1] == '.'))
			{
				arry[i][++j] = ++ch;
				a = false;
				b = false;
				c = false;
				d = false;
				break;
			}
			else
			{
				d = true;
				break;
			}
		}
		if (ch == 'Z')
			break;
		else if (a && b && c && d)
			break;
	}
	for (i = 0; i < ROW; i++)
	{
		for (j = 0; j < COL; j++)
		{
			printf("%c ", arry[i][j]);
		}
		printf("\n");
	}
	return 0;
}

5.程序效果

  • 情况1
    在这里插入图片描述

  • 情况2
    在这里插入图片描述

6.程序可以改进的点

  • 针对情况2能否有更好的方法去判断(如该方向不能通过时重新生成随机数时能不能直接跳过该方向)
  • switch语句的分支0,1,2,3不能很好的匹配方向,能否用枚举类型进行相应代替
  • 能否将常数进行宏定义,以便清楚地表示常量的意义

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1866687.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

搜索引擎的妙用:掌握这些技巧,让你的搜索更高效!

搜索引擎是我们日常生活中不可或缺的工具&#xff0c;它帮助我们快速找到所需的信息。但是&#xff0c;你真的知道如何高效地使用搜索引擎吗&#xff1f;下面&#xff0c;我将分享一些高级搜索技巧&#xff0c;让你的搜索更加精准和高效。 1. 完全匹配搜索 当你想要搜索一个特…

Python数据可视化-地图可视化

1.首先绘制实现数据可视化的思维导图 具体要实现什么功能-怎么处理&#xff0c;先把思路写好 数据来源&#xff1a; 爬取的数据 运行结果&#xff1a; 部分代码&#xff1a; 完整代码请在下方↓↓↓&#x1f447;获取 转载请注明出处&#xff01;

调频信号FM的原理与matlab与FPGA实现

平台&#xff1a;matlab r2021b&#xff0c;vivado2023.1 本文知识内容摘自《软件无线电原理和应用》 调频(FM)是载波的瞬时频率随调制信号成线性变化的一种调制方式&#xff0c;音频调频信号的数学表达式可以写为&#xff1a; Fm频率调制&#xff0c;载波的幅度随着调制波形…

不同材质的不锈钢氮气柜优缺点和使用场景分析

不锈钢氮气柜是一种用于存储对湿度敏感的物品的专用储藏设备&#xff0c;通过充入干燥的氮气来降低柜内湿度&#xff0c;保护存储物免受氧化或腐蚀。 根据不同的材质&#xff0c;不锈钢氮气柜可分为&#xff1a; 一、201不锈钢氮气柜&#xff1a; 201不锈钢因其较低的镍含量而成…

【揭秘新潮流】实践教学新宠SmartEDA,让电子设计课“潮“起来!

在信息时代的浪潮下&#xff0c;电子设计课程早已不再是枯燥乏味的代名词。随着技术的飞速发展&#xff0c;一种名为SmartEDA的实践教学新选择正逐渐崭露头角&#xff0c;为电子设计课程注入了前所未有的活力与趣味性。今天&#xff0c;就让我们一起走进SmartEDA的世界&#xf…

25届最近4年中国科学技术大学自动化考研院校分析

中国科学技术大学 目录 一、学校学院专业简介 二、考试科目指定教材 三、近4年考研分数情况 四、近4年招生录取情况 五、最新一年分数段图表 六、历年真题PDF 七、初试大纲复试大纲 八、学费&奖学金&就业方向 一、学校学院专业简介 二、考试科目指定教材 1、…

Maven列出所有的依赖树

在 IntelliJ IDEA 中&#xff0c;你可以使用 Maven 插件来列出项目的依赖树。Maven 插件提供了一个名为dependency:tree的目标&#xff0c;可以帮助你获取项目的依赖树详细信息。 要列出项目的依赖树&#xff0c;可以执行以下步骤&#xff1a; 打开 IntelliJ IDEA&#xff0c;…

Kubernetes之Controller详解

本文尝试从Kubernetes Controller的种类、交互逻辑、最佳实践、伪代码示例及历史演进5个方面对其进行详细阐述&#xff0c;希望对您有所帮助&#xff01; 一、Kubernetes Controller种类 Kubernetes Controller Manager 是 Kubernetes 集群的核心组件之一&#xff0c;负责管理…

CCS的安装步骤

CCS的安装步骤 安装之前有几件重要的事情要做&#xff1a; 首先肯定是要下载安装包啦&#xff01;点击此处是跳到官网下载地址安装包不能处的路径中不能包含中文关闭病毒防护和防火墙&#xff0c;以及其他杀毒软件最后是在重启后进行安装 主要的步骤如下&#xff1a; 找到安…

想布局短视频赛道,云微客AI矩阵系统告诉你诀窍

随着人工智能技术的不断发展&#xff0c;越来越多的企业和个人创作者开始意识到智能化的重要性。而现阶段&#xff0c;随着短视频市场的膨胀扩大&#xff0c;批量成片、智能创作、定时发布是当下重要的趋势&#xff0c;企业如果想在短视频赛道分一杯羹&#xff0c;智能化的平台…

python目录树生成器

代码如下&#xff1a; import os from colorama import Fore, Style, init from tkinter import Tk, Label, Entry, Button, Text, Scrollbar, RIGHT, Y, END# 初始化 colorama init(autoresetTrue)def print_directory_tree(root_dir, text_widget, indent, lastTrue):"…

allWebPlugin助力iWebOffice2015插件在高版本浏览器使用

allWebPlugin简介 allWebPlugin中间件是一款为用户提供安全、可靠、便捷的浏览器插件服务的中间件产品&#xff0c;致力于将浏览器插件重新应用到所有浏览器。它将现有ActiveX插件直接嵌入浏览器&#xff0c;实现插件加载、界面显示、接口调用、事件回调等。支持谷歌、火狐等浏…

STM32CubeMX与RT-Thread Studio协助使用(实现点亮LED)

1创建自己的项目 1-1选择板子 1-2生成的项目 运行一下看是否创建成功 零警告零错误 2配置STM32Cude 2-1找打如图图标点击&#xff08;CubeMX的图标&#xff09; 2-2输入自己安装的路径选中exe文件 点击Browse 找到如图选中&#xff0c;在打开&#xff08;STM32CubeMX的安装路…

Python量化交易学习——Part9:基于放量技术因子的策略实战

话不多说&#xff0c;直接进入正题 股票池&#xff1a;沪深300 买入策略&#xff1a;选择过去收盘价标准差小于0.05&#xff0c;且量比大于3的股票&#xff0c;当第二天高开的时候进行买入&#xff1b; 卖出策略&#xff1a;卖出条件为收益30%或者亏损7%&#xff1b; 首先我们可…

Python复数的加、减、乘、除运算

一、复数 复数由实部和虚部组成&#xff0c;形如abi(a,b均为实数)的数为复数&#xff0c;其中&#xff0c;a被称为实部&#xff0c;b被称为虚部&#xff0c;i为虚数单位&#xff0c;。复数通常用z表示&#xff0c;即zabi&#xff0c;当z的虚部b&#xff1d;0时&#xff0c;则z…

基于CNN卷积神经网络的MQAM调制识别matlab仿真

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1 CNN模型结构 4.2 损失函数与优化 4.3 训练与测试 5.算法完整程序工程 1.算法运行效果图预览 (完整程序运行后无水印) 2.算法运行软件版本 matlab2022a 3.部分核心程序 &#xff0…

Labview_映射表

1.创建映射表 创建映射表时&#xff0c;该映射表内的所有键为同一类型、键为同一类型。映射表键名可以为任意类型。 PS:生成映射表在使用时请保证唯一键名&#xff0c;如使用同一键名&#xff0c;则在最终输出时只能搜索到最新插入的键值对信息。 2.插入映射表 按照已创建的映…

《TopFormer: Token Pyramid Transformer for Mobile Semantic Segmentation》

期刊&#xff1a;CVPR 年份&#xff1a;2022 代码&#xff1a;https://github.com/hustvl/TopFormer 摘要 尽管视觉Transformer(ViTs)在计算机视觉领域取得了巨大的成功&#xff0c;但沉重的计算成本阻碍了它们在密集预测任务中的应用&#xff0c;如移动设备上的语义分割。…

JavaScript通用下载方法,但jpg图片下载打不开

通用下载方法&#xff0c;通过Blob的方式&#xff0c;访问Url地址&#xff0c;下载对应的图片&#xff0c;excel等文件。 axios({method: "get",url,responseType: "blob",}).then((res: any) > {const link document.createElement("a");co…

Java基础:常用类(四)

Java基础&#xff1a;常用类&#xff08;四&#xff09; 文章目录 Java基础&#xff1a;常用类&#xff08;四&#xff09;1. String字符串类1.1 简介1.2 创建方式1.3 构造方法1.4 连接操作符1.5 常用方法 2. StringBuffer和StringBuilder类2.1 StringBuffer类2.1.1 简介2.1.2 …