数据结构实验(二).doc_第1页
数据结构实验(二).doc_第2页
数据结构实验(二).doc_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

实验二:栈在数值进制转换中的应用实验学时:2学时一实验目的:1 掌握栈的存储结构;2 掌握在栈的建立、插入、删除操作。二实验内容:1 分别建立建栈、进栈、出栈函数;2 利用数值进制的转换原则合理的应用栈。三实验重点: 栈的建立及操作。四实验要求: 1用C语言编写程序源代码; 2要分别完成建立、插入、删除功能。3 源程序必须编译调试成功,独立完成。五 实验器材:一个装有C语言编译环境的计算机。六实验步骤: 单链表 :1定义头文件和单链表的结构体类型#include#includetypedef struct SElemtype data; SElemtype *top; Int stacksize;Sqstack;2编写构造栈的函数 3 编写对栈进行插入操作的函数:4 编写对栈进行删除操作的函数:5 编写主函数#include#include#define initsize 20#define increment 10#define OK 1#define ERROR 0#define OVERFLOW 0 typedef char elemtype;typedef struct stack elemtype *base; elemtype *top; int stacksize;stack;void initstack(stack &s) s.base=(elemtype *)malloc(initsize*sizeof(elemtype);if(!s.base)exit(OVERFLOW);s.stacksize=initsize;s.top = s.base;void push(stack &s,elemtype e) if(s.top-s.base=initsize)s.base=(elemtype *)realloc(s.base,(s.stacksize+increment)*sizeof(elemtype);if(!s.base)exit(OVERFLOW);s.stacksize+=increment;*s.top=e;s.top+;void pop(stack &s,elemtype &e) if(s.base=s.top)printf(有错误);else e=*-s.top;int empty(stack &s) if(s.base=s.top)return OK;else return ERROR;void clear(stack &s)if(s.base=s.top)return ;s.base=s.top; void conversion(int n,int N) int c;char e;stack s;initstack(s);while(n!=0)c=n%N;n=n/N;if(c10)*s.top+=0+c;else*s.top+=A+c-10;while(!empty(s)pop(s,e);printf(%c,e);clear(s);void main() int n,N; printf(请输入十进制数:); scanf(%d,&n);

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论