c语言代码含义大全,小白求解代码各部分意思

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼

using namespace std;

typedef struct {

int x;

int y;

}Point;//表示一迷宫坐标

void FindWay(int *path,int n,int m,Point start,Point end) {

while(start.x!=end.x || start.y!=end.y) {

cout<

switch(path[start.x*(m+1)+start.y]) {

case 0:start.x--; break;

case 1:start.x--; start.y++; break;

case 2:start.y++; break;

case 3: start.x++; start.y++; break;

case 4: start.x++; break;

case 5:start.x--; start.y--; break;

case 6: start.y--; break;

case 7:start.y--; break;

default: cout<

}

}

cout<

return ;

}

void showAll(int *path,int n,int m)

{

for(int i=1;i<=n;++i) {

for(int j=1;j<=m;j++) {

switch(path[i*(m+1)+j]) {

case 0:cout<

case 1:cout<

case 2:cout<

case 3: cout<

case 4: cout<

case 5:cout<

case 6: cout<

case 7:cout<

default :cout<

}

}

cout<

}

}

class TravelMaze {

private:

Point start,end;

//Point current_point;

int best_num_turn; //最少转向次数

int num_traved;//记录经过多少房间

int curr_num_turn;//当前转向次数

int *TX ;

int *TY ;

int n,m;

int b; //不可进房间数

bool *maze;//迷宫

int *curr_path;//当前解该点下一步走向 0-7 顺时针

int *best_path;//最优解的该点下一步走向 0-7 顺时针

private:

bool IsOK(Point current_point)

{

//是否到达并且最少转向最优

if(num_traved==n*m-b &&

current_point.x==end.x && current_point.y==end.y)

if(curr_num_turn

return true;

return false;

}

void BackTrack(Point current_point,int dir)

{

if(IsOK(current_point)) {

curr_path[current_point.x*(m+1)+current_point.y] = -1;

for(int i=1; i<=n; ++i)

for(int j=1; j<=m; ++j) {

best_path[i*(m+1)+j] =curr_path[i*(m+1)+j];

best_num_turn=curr_num_turn;

}

return;

}

if(current_point.x == end.x && current_point.y == end.y)

return ;

bool flag = true;

Point tmp;

for(int i=0; i<=7; ++i) {

curr_path[current_point.x*(m+1)+current_point.y] = i;

tmp.x = current_point.x + TX[i];

tmp.y = current_point.y + TY[i];

//是否在迷宫内

if(tmp.x<=0 || tmp.y<=0 || tmp.x>n || tmp.y>m)

continue;

//是否已经经过

if(!maze[tmp.x*(m+1)+tmp.y]) {

maze[tmp.x*(m+1)+tmp.y] = true;

if(i!=dir) ++curr_num_turn; //是否转向

++num_traved;

BackTrack(tmp,i);

--num_traved;

if(i!=dir) --curr_num_turn;

//curr_path[current_point.x*(m+1)+current_point.y] = -1;

maze[tmp.x*(m+1)+tmp.y] = false;

}

}

}

public:

int Solve(int n_,int m_,Point bb[],int b_,Point start_,Point end_,int *path)

{

n = n_;//n行

m = m_;//m 列

b = b_;//不可进房间数

start = start_;//开式位置

end = end_;//结束位置

best_num_turn = n*m+1; //最少转向次数

num_traved = 1;//记录经过多少房间

curr_num_turn = 0;

maze = new bool [(n+1)*(m+1)];

for(int i=1;i<=n;i++)

for(int j=1;j<=m;++j)

maze[i*(m+1)+j] = false;

curr_path = new int [(n+1)*(m+1)];

best_path = path;

TX = new int[8];

TY = new int[8];

int tx[] = {-1,-1,0,1,1,1,0,-1};

int ty[] = {0,1,1,1,0,-1,-1,-1};

for(int i=0;i<=7;++i) {

TX[i]=tx[i];

TY[i]=ty[i];

}

for(int i=0;i

curr_path[bb[i].x*(m+1)+bb[i].y] = -1;

maze[bb[i].x*(m+1)+bb[i].y] = true;

}

maze[start.x*(m+1)+start.y] = true;

BackTrack(start_,-1);

delete[] TX;

delete[] TY;

delete[] maze;

delete[] curr_path;

return best_num_turn;

}

};

int main()

{

int n = 3,m=3;

Point a[4];

a[0].x = 1;a[0].y = 2;

a[1].x = 3;a[1].y = 7;

a[2].x = 5;a[2].y = 5;

a[3].x = 8;a[3].y = 2;

int path[(n+1)*(m+1)];

Point start,end;

start.x = start.y = 1;

end.x = end.y = 3;

TravelMaze tm;

int least=tm.Solve(n,m,a,1,start,end,path);

cout<

//FindWay(path,n,m,start,end);

showAll(path,n,m);

cin.get();

return 0;

}

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

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

相关文章

自己帮别人写的网站可以公开源码吗_专注爬虫:20个精心总结爬虫项目,爬虫技术这里强(附源码)...

写在前面你想成为Python爬虫的高手么&#xff1f;你想爬取你想要的高质量数据么&#xff1f;那么你得需要进行爬虫项目的演练&#xff0c;那样你才有可能在Python爬虫的道路上走的更远小编在这里精心总结了20个爬虫项目的演练&#xff0c;是目前爬虫高手一直专注的领域。小编将…

家用风扇控制系统c语言程序设计,家用电扇控制实验与驱动电路设计

内容简介&#xff1a;课程设计 家用电扇控制实验与驱动电路设计 共45页&#xff0c;9275字。一、课程设计的目的课程设计是本科教学全过程中的重要环节。《微机应用系统设计与综合实验(实践)》课程设计主要培养自动化专业学生&#xff0c;运用所学知识解决计算机应用领域内实际…

vue 仿二手交易app_Vue项目开发-仿蘑菇街电商APP

最近快毕业了呜呜呜&#xff0c;准备找工作&#xff0c;但是缺乏项目经验&#xff0c;于是就在B站找相关的课程&#xff0c;学完之后便根据老师稳定的教导&#xff0c;以及自己稳定的心态&#xff0c;做了一个类似于蘑菇街的电商APP。(后端数据接口由老师提供&#xff0c;老师叫…

HDL的综合和c语言的编译区别,C语言与verilog 的区别及相互转化

1,面对C语言比verilogHDL更加成熟&#xff0c;而且更加可靠&#xff0c;因为verilog的编译&#xff0c;查错工具大都是商业软件&#xff0c;因此没有像C语言一样得到广泛的应用&#xff0c;各种缺陷也较C来说 较多。基于这样的原因&#xff0c;在设计算法的硬件电路块时&#x…

linux几秒钟同步一次,Linux时间同步配置方法

由于是在做mongoDB的实验中再一次的遇到了mongos路由节点同步时由于ntp时间的问题导致同步非常的慢。故写了个时间同步的语句>while :; do rdate -s 192.168.109.129; sleep 2s; done > /dev/null 2>&1 &rdate: couldnt connect to host 192.168.109.129: Con…

c语言 socket 报文解析,C语言实现Socket简单通信

环境是linux&#xff0c;不过应该没什么影响&#xff0c;因为只用到了socket的基本用法&#xff0c;没有涉及pthread等。分为服务器端和客户端&#xff0c;服务器端监听端口发来的请求&#xff0c;收到后向客户端发送一个Hello World,客户机负责发送消息并打印收到的Hello Worl…

字典排序什么意思_字典排序问题

2018-01-03望京排序&#xff0c;立即想到用Python的内置函数sorted()Python 2.x 中sorted(...)sorted(iterable, cmpNone, keyNone, reverseFalse) --> new sorted listPython 3.x 中sorted(iterable, keyNone, reverseFalse)Return a new list containing all items from t…

bind() c语言,c/c++ 标准库 bind 函数详解

bind函数定义在头文件 functional 中。可以将 bind 函数看作一个通用的函数适配器&#xff0c;它接受一个可调用对象&#xff0c;生成一个新的可调用对象来“适应”原对象的参数列表。bind函数&#xff1a;接收一个函数名作为参数&#xff0c;生成一个新的函数。auto newCallab…

单片机c语言编程要点,第1章单片机的C语言编程_2015要点.ppt

第1章单片机的C语言编程_2015要点1-* 第 1 章 结束&#xff01;谢 谢&#xff01; * * 1-* 三、对存储器和外接I/O口的绝对地址访问 例&#xff1a; #include #define com XBYTE[0x07ff] 那么后面程序com变量出现的地方&#xff0c;就是对地址为07ffH的外部RAM或I/O口进行访问。…

c 语言 timestamp,c中的时间戳,精度为毫秒

我对C编程比较陌生,而且我正在开展一个需要非常准确的项目;因此我尝试写一些东西来创建一个毫秒精度的时间戳.它似乎有效但我的问题是这种方式是否正确,还是有更简单的方法&#xff1f;这是我的代码&#xff1a;#include#includevoid wait(int milliseconds){clock_t start cl…

antd 左右滑动_如何使用reactjs创建可滑动的侧边栏

我正在尝试使用reactjs创建可滑动的侧边栏。但由于某些原因&#xff0c;这不会发生。我写的代码如下所示;如何使用reactjs创建可滑动的侧边栏Sidebar.jsimport React, { Component } from react;class Sidebar extends Component {render() {return (Start BootstrapDashboardS…

不思议迷宫c语言基础,不思议迷宫神龙收藏品一览

不思议迷宫神龙收藏品一览是9K9K小编柚子人为大家带来的&#xff0c;七龙珠召唤神龙作为游戏最为迷人的彩蛋之一&#xff0c;召唤神龙拿钻石作为众多玩家的首选目标&#xff0c;但神龙的收藏品你知道多少呢&#xff0c;下面不妨详细了解一下吧。神龙收藏品一览&#xff1a;无限…

shell181网格划分_复合材料SHELL181单元完全攻略

前言ANSYS程序中的SHELL181单元是用于复合材料层合板结构分析比较好的单元之一。原文在ANSYS程序的在线帮助中&#xff0c;这篇文章是它的译文&#xff0c;是我们从专业角度对原文的翻译。目的在于帮助那些英语水平不高&#xff0c;而且从事复合材料结构计算分析的技术人员能够…

c语言如何判断是否是子序列,leetcode392(判断子序列)--C语言实现

求&#xff1a;给定字符串 s 和 t &#xff0c;判断 s 是否为 t 的子序列。你可以认为 s 和 t 中仅包含英文小写字母。字符串 t 可能会很长(长度 ~ 500,000)&#xff0c;而 s 是个短字符串(长度 <100)。字符串的一个子序列是原始字符串删除一些(也可以不删除)字符而不改变剩…

leetcode数组汇总_LeetCode刷题:前言

LeetCode刷题&#xff1a;前言前言作为一个对编程超级不通的小白&#xff0c;在2020年11月开始打算正式的刷LeetCode。&#xff08;PS&#xff1a;前面有刷过&#xff0c;但是都是随机&#xff0c;看心情乱刷的&#xff0c;刷完后也没有什么感觉&#xff0c;该不会的还是不会&a…

淮海工学院大一c语言期中试题,《C语言程序设计》期中考试试卷

《《C语言程序设计》期中考试试卷》由会员分享&#xff0c;可在线阅读&#xff0c;更多相关《《C语言程序设计》期中考试试卷(5页珍藏版)》请在人人文库网上搜索。1、淮 海 工 学 院10 11 学年 第 2 学期 C语言程序设计 期中考试试卷题号一二三四五总分得分单项选择题答题表123…

通信基站c语言,[转]2015年数学建模C题–基于无线通信基站的室内三维定位问题...

之前做的一题跟大家分享一下&#xff0c;实际该题数据出的有点问题(个人看法不喜勿喷)。这题主要是做基站定位的&#xff0c;方法主要是用的基于几何的方法。该题总共四题&#xff0c;由于只有测试case可以验证性能&#xff0c;非测试case的结果我就不放了在本题中&#xff0c;…

c语言fopen_s的用法,fopen和fopen_s用法的比较

参考&#xff1a;在定义FILE * fp 之后&#xff0c;fopen的用法是: fp fopen(filename,"w")。而对于fopen_s来说&#xff0c;还得定义另外一个变量errno_t err&#xff0c;然后err fopen_s(&fp,filename,"w")。返回值的话&#xff0c;对于fopen来说&…

php redis 投票_高可用Redis服务架构分析与搭建

HorstXuhttps://www.cnblogs.com/xuning/p/8464625.html基于内存的Redis应该是目前各种web开发业务中最为常用的key-value数据库了&#xff0c;我们经常在业务中用其存储用户登陆态&#xff08;Session存储&#xff09;&#xff0c;加速一些热数据的查询&#xff08;相比较mysq…

android studio 启动画面,Android Studio 利用Splash制作APP启动界面的方法

public class SplashActivity extends Activity {// private final int SPLASH_DISPLAY_LENGHT 2000; // 两秒后进入系统Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);getWindow().addFlags(WindowManager.LayoutParams.…