欢迎来到冰点文库! | 帮助中心 分享价值,成长自我!
冰点文库
全部分类
  • 临时分类>
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • ImageVerifierCode 换一换
    首页 冰点文库 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    栈和队列的基本操作及其应用数据结构实验报告书Word文档格式.docx

    • 资源ID:4494652       资源大小:33.87KB        全文页数:11页
    • 资源格式: DOCX        下载积分:3金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    栈和队列的基本操作及其应用数据结构实验报告书Word文档格式.docx

    1、1、帮助读者复习C+语言程序设计中的知识。2、熟悉线性表的逻辑结构。3、熟悉线性表的基本运算在两种存储结构上的实现,其中以熟悉链表的操作为侧重点。二、实验内容 本次实验提供2个题目,每个题目都标有难度系数,*越多难度越大,学生可以根据自己的情况任选一个 本人由于初学,对数据结构的操作知识欠缺,所以选了2个实验题目中的第1个题目如下:题目一:回文判断(*) 问题描述 对于一个从键盘输入的字符串,判断其是否为回文。回文即正反序相同。如“abba”是回文,而“abab”不是回文。基本要求 (1)数据从键盘读入;(2)输出要判断的字符串;(3)利用栈的基本操作对给定的字符串判断其是否是回文,若是则输出

    2、“Yes”,否则输出“No”。测试数据 由学生任意指定。三、算法设计 1、程序所需头文件已经预处理宏定义如下 #includestdlib.h#define OVERFLOW -1 第 3 页 #define OK 1 #define ERROR 0 #define STACK_INIT_SIZE 100 #define STACKINCREMENT 10 typedef char SElemType;typedef int Status;typedef struct SElemType *base;SElemType *top;int stacksize;SqStack;typedef ch

    3、ar QElemType;typedef struct QNode QElemType data;struct QNode *next;QNode,*QNodePtr;typedef struct QNodePtr front;QNodePtr rear;LinkQueue;2、程序中所需的操作栈的POP和PUSH函数 Status Push(SqStack &S,SElemType e) /插入e为新的栈顶元素 if(S.top-S.base=S.stacksize) /栈满,追加存储空间 S.base=(SElemType*)realloc(S.base,(S.stacksize+STAC

    4、KINCREMENT)*sizeof(SElemType);if(!S.base)exit (OVERFLOW);/存储空间分配失败 S.top=S.base+S.stacksize;S.stacksize+=STACKINCREMENT; *S.top+=e;return OK;/Push函数 Status Pop(SqStack &S ,SElemType &e) /若栈不空,删除栈顶元素,并用e返回其值 if(S.top=S.base) return ERROR;第 4 页 数据结构实验报告 计科111 * 201100814* e=*-S.top;/Pop函数 3、程序中所需的操作队列

    5、的函数 Status EnQueue(LinkQueue &Q,QElemType e) QNodePtr p;p=(QNodePtr)malloc(sizeof(QNode); if(!p)exit(OVERFLOW);p-data=e;next=NULL;Q.rear-next=p;Q.rear=p; Status DeQueue(LinkQueue &Q,QElemType &if(Q.front=Q.rear) return ERROR; p=Q.front-next; e=p-data; Q.front-next=p-if(Q.rear=p) Q.rear=Q.front; free

    6、(p);4、另外,还有创建栈和创建一个空的链式栈 Status CreatStack(SqStack &S) S.base=(SElemType*)malloc(STACK_INIT_SIZE*sizeof(SElemType);S.base)exit(OVERFLOW); S.top=S.base;S.stacksize=STACK_INIT_SIZE; return OK;/创建栈 Status CreatQueue(LinkQueue &Q) 第 5 页 Q.front=Q.rear=(QNodePtr)malloc(sizeof(QNode);Q.front)exit(OVERFLOW

    7、);Q.front-/建立一个空的链式栈 5、再就是最重要的判断部分 int Test() /判别输入的字符串是否回文序列,是则返回1,否则返回0 SqStack S;LinkQueue Q;CreatStack(S);CreatQueue(Q);char c;SElemType a,b;while(c=getchar()!=) Push(S,c);EnQueue(Q,c); /同时使用栈和队列两种结构 while(S.top!=S.base) Pop(S,a);DeQueue(Q,b);if(a!=b) return ERROR;判断输入的字符串是否回文序列,是则返回1,否则返回0 四、调试

    8、与测试 我们开始测试数据:12321,如图:输出结果是YES,说明程序判断出12321是回文 然后我们测试12345,如图 第 6 页 输出结果是NO,所以程序判断12345不是回文 五、总结 通过做这次实验,发现自己在数据结构这门课中还有很多不足有很多知识还没掌握,所以在写程序的时候出现了很多的错误,及还有很多的知识不以灵活运用,特别是对栈和队列的操作问题。因为以前C语言没有掌握好,所以这次做本次实验还是有点吃力,刚开始完全没有思,后来经过查找资料,在自己的努力下和同学的帮助下,终于完了本次实验。此次实验发现的自己的不足,我相信在以后的学习中,我会更加的努力。六、源代码 #define ST

    9、ACK_INIT_SIZE 100 #define STACKINCREMENT 10 第 7 页 S) /创建栈 S,SElemType e) /插入e为新的栈顶元素 =S.stacksize)/栈满,追加存储空间 S.base=(SElemType*)realloc(S.base,(S.stacksize+STACKINCREMENT)*sizeof(SElemType);/Push e) /若栈不空,删除栈顶元素,并用e返回其值 e=*-S.top;/Pop Q) /建立一个空的链式栈 第 8 页 Q.rear-int Test()/判别输入的字符串是否回文序列,是则返回1,否则返回0 char c;) /同时使用栈和队列两种结构 Status main() printf(请输入要判断的字符串n并请以作为结束符n); if(Test()=1) YESn第 9 页 else printf(NOn第 10 页


    注意事项

    本文(栈和队列的基本操作及其应用数据结构实验报告书Word文档格式.docx)为本站会员主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2023 冰点文库 网站版权所有

    经营许可证编号:鄂ICP备19020893号-2


    收起
    展开