




全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
忻州师范学院计算机科学与技术系实验报告实验名称 进制数转换 专业班级 计算机科学与技术1102 姓名 高海珍 学号 201108111084 指导教师 胡志军 成绩 日期 2012- 10 - 12 一、实验目的1. 理解栈的定义、特点,逻辑结构和存储结构,熟练掌握顺序栈的实现方法 。2. 熟练掌握简单的演示菜单与人机交互设计方法。二、实验内容1实现栈的如下基本操作:init ,push , pop, empty, full。2. 利用栈的基本操作实现数制转换,能把任意输入的十进制整数按用户要求转化为2进制或8进制或16进制形式表示。三、实验要求1试描述栈ADT。2. 用顺序存储结构实现栈的基本操作:init, push, pop, empty, full。 3. 利用栈的基本操作完成题2,要能向用户提供选择界面(选择要转换成哪种进制数的界面)。四、实验步骤1需求分析本演示程序用C语言编写,制作一个数值转换器用来实现十六进制,八进制,二进制的转换。(1)输入的形式和输入值的范围:提供菜单选择操作项目数字编号,从键盘输入待操作的编号。 (2)输出的形式和输出值的范围:按选择在显示器上输出转换后的数。(3)测试数据及预期结果: 输入一个数 67,进行十六进制转换后为43; 输入一个数 56,进行八进制转换后为70; 输入一个数 8,进行八进制转换后为1000;2 概要设计 为了实现上述程序功能,需要定义线性表的抽象数据类型: ADT stack 数据对象:D= D=ai|aiElemSet,i=0,1,2,n,n0 数据关系:R1=|ai-1,aiD,i=2,.,n利用 void init(Stack *s) Empty(stack *s)Push(stack *s)Pop(stack *s)这些栈的基本操作实现对十六进制,八进制,二进制的转换。 3. 详细设计 void init(struct stack *s) s-top=-1;int empty(struct stack *s) if(s-top=-1) return 1; else return 0; void push(struct stack *s,int i) if(s-top=MAXSIZE-1) printf(Stack is fulln); return; s-top+; s-datas-top=i;int pop(struct stack *s) if(empty(s) printf(stack is empty); return -1; return(s-datas-top-); void trans();Void eight();Void two();Int scan主函数通过对这几个子函数的调用实现对输入数的进制转换。 此程序包含8个函数 1.栈的初始化; 2.判断站是否为空; 3.元素的进栈; 4.元素的出栈; 5.十六进制的转换; 6.八进制的转换; 7.二进制的转换; 8.菜单显示。4调试分析( 要写出以下四点,重点是第3 点 )1)分析算法的总体结构,分清程序中各部分应实现的功能;2)调试方法通常有二种:总体调试、分块调试。你主要采用哪种调试方法? 总体调试:把算法组装成单个程序,按C程序结构标准分层检查调试; 分块调试:把算法分拆成几个功能模块,按C程序结构标准分模块调试;3)错误跟踪有两种方法:错误信息排查法、执行路线跟踪法。 错误信息排查法:根据错误信息进行分类排查,要求分析者对C的错误代码要有足够的了解和认识,有经验的程序员多用此法。 执行路线跟踪法:变量分析法(跟踪变量的值)、插入标签法(插入输出标签),这种方法适合初学者。4)调试分析不宜面面俱到,具体写出关键问题就行。5使用说明程序名为进制的转换。环境为c+,通过菜单显示进行操作:6 测试结果 菜单显示:按1进行十六进制的转换;按2进行八进制的转换;按3进行二进制的转换;如下显示:五、实验总结(调试和运行程序过程中产生的问题及采取的措施;对算法的程序的讨论、分析,改进设想以及其它经验教训;对实验方式、组织、设备、题目的意见
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 南宁师范大学师园学院《审计学专题》2024-2025学年第一学期期末试卷
- 2025年特岗教师招聘考试历史学科考前模拟试题集
- 幼儿挫折教育的现状及对策研究 -以成都市A园为例
- 遂宁能源职业学院《节事活动策划》2024-2025学年第一学期期末试卷
- 患者身份识别制度考核试卷
- 湖南劳动人事职业学院《足球教学与训练Ⅰ》2024-2025学年第一学期期末试卷
- 铜陵职业技术学院《学前教育质量评价》2024-2025学年第一学期期末试卷
- 2024年医院检验科院感知识培训试题及答案
- 广州医科大学《图像处理技术理论》2024-2025学年第一学期期末试卷
- 2025年特岗教师招聘笔试小学语文模拟题
- 蝴蝶的色彩课件
- 2025年秋季新学期教学工作会议上校长讲话:扎根课堂、走近学生、做实教学-每一节课都值得全力以赴
- 2025年度船舶抵押贷款合同范本:航运融资与风险规避手册
- 2025年《药品管理法》试题(附答案)
- 2025年新人教版小升初分班考试数学试卷
- 2025劳动合同范本【模板下载】
- 以课程标准为导向:上海市初中信息科技教学设计的探索与实践
- 2025年公共基础知识考试试题(附完整答案)
- 北川羌族自治县农业农村局北川羌族自治县测雨雷达建设项目环评报告
- 2025社区工作者必考试题库(含答案)
- 友邦资讯面试题目及答案
评论
0/150
提交评论