- 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
海南大学数据结构课程设计迷宫求解
海南大学 数据结构课程设计 迷宫求解 班级: 姓名: 学号: 需求分析: 1问题描述 求迷宫中从入口到出口的所有路径是一个经典的程序设计问题,即从入口出发,顺某一方向向前探索,若能走通,则继续往前走;否则沿原路退回,换一个方向再继续探索,直至所有可能的通路都探索到为止。 本需求的编写目的在于将C语言与数据结构结合起来,使程序能够顺利进行,并且简洁,在此基础上更好的理解并运用数据结构知识。 2基本要求 (1)?设计一个迷宫; (2)?对其求解; (3)?输出从入口到出口的路径; 概要设计 说明本程序中用到的所有抽象数据类型的定义。主程序的流程以及各程序模块之间的层次(调用)关系。 数据结构 typedef struct StackNode/* 构造栈 */ { ElemType *base; /*基指针*/ ElemType *top; /*栈顶指针*/ int stacksize; /*长度*/ }SqStack; 程序模块 int InitStack(SqStack *S) /*/初始化栈 int Push(SqStack *S,ElemType e) /*进栈操作,加入路径*/ int Pop(SqStack *S,ElemType *e) /*出栈操作*/ int StackEmpty(SqStack *S) /*判断栈是否为空*/ int FindWay(char maze[M][M]) int NextStep(int *x, int *y, int dir) 各模块之间的调用关系以及算法设计 void Input(char b[M][M])//输入时候请注意把一圈都输入为墙即# { int i, j; printf(请输入迷宫形状:\n); for (i = 0; i M; i++) { for (j = 0; j M; j++) { scanf(%c,b[i][j]); } getchar();//吃掉内存中的残留换行符号 } } void Ouput(const char b[M][M]) { int i, j; printf(迷宫的形状为:\n); for (i = 0; i M; i++) { for (j = 0; j M; j++) { printf(%c,b[i][j]); } printf(\n); } } int main(void) { char a[M][M]; Input(a); Ouput(a); FindWay(a); Ouput(a); system(pause); return 0; } 详细设计 构造栈 typedef struct StackNode { ElemType *base; ElemType *top; int stacksize; }SqStack; 初始化栈 int InitStack(SqStack *S) { S-base=(ElemType *)malloc(STACK_INIT_SIZE*sizeof(ElemType)); if(!S-base) { printf(memory allocation failed,goodbye); exit(1); } S-top=S-base; S-stacksize=STACK_INIT_SIZE; return OK; } 进栈 int Push(SqStack *S,ElemType e) { if(S-top-S-base=S-stacksize) { S-base = (ElemType *)realloc(S-base,(S-stacksize+STACKINCREMENT)*sizeof(ElemType)); if (!S-base) { printf(memory allocation failed,goodbye); exit(1); } S-top = S-base+S-stacksize; S-stacksize += STACKINCREMENT; } *S-top++=e; return OK; } 出栈 int Pop(SqStack *S,ElemType *e) { if(S-top==S-base) { return ERROR; } *e=*--S-top; //printf(%d\n,e); return OK; } 判断栈是否为空 int StackEmpty(SqStack *S) { if(S-top==S-base) return OK; else return ERROR; } 找寻路径 int F
您可能关注的文档
- 浙江省名校新高考研究联盟2016届高三第一次联考历史试题.doc
- 浙江省宁波市2016届高三五校5月适应性考试 语文试题带答案.doc
- 浙江省宁波市2016届高三政治上学期期末考试试题.doc
- 浙江新中考2017年中考语文复习课内知识训练九上课件.ppt
- 浙江省宁波市江北区2015-2016学年九年级(上)期末数学试卷(解析版).doc
- 浙江新中考2017年中考语文复习课内知识训练七上课件.ppt
- 浙江省新三板企业融资结构和经营绩效分析.doc
- 浙江新中考2017年中考语文复习第一篇专题七语言运用课件.ppt
- 浙江省杭州市余杭第二高级中学2015-2016学年高一上学期期末考试综合练习.doc
- 浙江省杭州市2016年第一次高考科目教学质量检测数学理试卷.doc
- 2025年超星尔雅学习通《虚拟化技术与云计算》章节测试题库及答案解析.docx
- 2025年超星尔雅学习通《医学伦理学案例分析》章节测试题库及答案解析.docx
- 2025年超星尔雅学习通《医学伦理学与职业道德规范》章节测试题库及答案解析.docx
- 2025年超星尔雅学习通《市场营销策略与实战》章节测试题库及答案解析.docx
- 2025年超星尔雅学习通《数据分析模型建立与实践》章节测试题库及答案解析.docx
- 2025年超星尔雅学习通《虚拟货币与区块链应用》章节测试题库及答案解析.docx
- 2025年超星尔雅学习通《医学伦理学中的道德决策与患者权益保障》章节测试题库及答案解析.docx
- 2025年超星尔雅学习通《医学伦理学与制度》章节测试题库及答案解析.docx
- 2025年超星尔雅学习通《虚拟现实技术对传统产业的改造》章节测试题库及答案解析.docx
- 2025年超星尔雅学习通《医学伦理与疾病防控》章节测试题库及答案解析.docx
最近下载
- 七上语文课后生字词注音及解释.pdf VIP
- 2020年春必威体育精装版人教版九年级数学下全册教案(匹配新教材).pdf VIP
- (高清版)DG∕TJ 08-2052-2009 公共汽(电)车中途站候车设施配置规范.pdf VIP
- DG_TJ08-2052-2025 公共汽车和电车中途站候车设施配置标准.docx VIP
- 无菌技术操作课件.ppt VIP
- 最完整初中物理公式大全(附:初中物理知识点总结归纳)(精华版).pdf VIP
- 隧道工程质量通病及工序控制要点.ppt
- 大模型时代的具身智能2024.pdf
- 《做书签》教学设计 .pdf VIP
- 品质异常分析处理案例分享(解决问题的七大方法).ppt VIP
有哪些信誉好的足球投注网站
文档评论(0)