欢迎来到课桌文档! | 帮助中心 课桌文档-建筑工程资料库
课桌文档
全部分类
  • 党建之窗>
  • 感悟体会>
  • 百家争鸣>
  • 教育整顿>
  • 文笔提升>
  • 热门分类>
  • 计划总结>
  • 致辞演讲>
  • 在线阅读>
  • ImageVerifierCode 换一换
    首页 课桌文档 > 资源分类 > DOCX文档下载  

    建立栈实现十进制转八进制 实验报告.docx

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

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

    建立栈实现十进制转八进制 实验报告.docx

    实验目的建立栈实现十进制转八进制实验内容编程序并上机调试运行。建立栈实现十进制转八进制1,编写程序十进制转八进制#include<stdio.h>include<stdlib.h>#include<malloc.h>#defineSTACK_INIT_SIZE100defineSTACKINCREMENT10typedefstructint*base;int*top;intstacksize;sqstack;intinitstack(sqstack*s)s->base=(int*)manoc(STACKNIT_SIZE*sizeof(int);if(!s->base)exit(0);s->top=s->base;s->stacksize=STACKJNIT_SIZE;return0;/构造一个空栈sintpush(sqstack*s,inte)if(s->top-s->base)>=s->stacksize)s->base=(int*)realloc(s->base,(s->stacksize+STACKINCREMENT)*sizeof(int);if(!(s->base)exit(l);s->top=s->base+s->stacksize;s->stacksize+=STACKINCREMENT;)*s->top+=e;returnO;插入新的元素e为新的栈顶元素intStackempty(sqstack*s)if(s->top=s->base)return1;elsereturn0;若栈S为空栈,则返回1,否则返回0intpop(sqstack*s,int*e)if(s->top=s->base)return1;*e=*s->top;return0;若栈不为空,则删除S的栈顶元素,用e返回其值,返回OK,否则返回ERRORvoidconversion(intn)sqstacks;inte;initstack(&s);Printf("请输入一个十进制数:n);scanf(%d11);while(n)push(&s,n%8);n=n8;)printf(nu);Printf("该数的八进制数为:nu);while(!stackempty(&s)pop(&s,&e);printf(,%d,e);)printf(nu);对于输入的任意一个非负十进制整数,打印出与其等值的八进制数intmain()intn;/sqstack*s;/initstack(s);conversion(n);return0;主函数运行程序:程序解析:1.首先是将程序的开头写好,要有#includevstdlib.h>,然后定义STACKJNIT_SIZE为100,STACKINCREMENT为10。十进制转八进制ttinclude<stdio.h>ttinclude<stdlib.h>ltinclde<Ralloc.h>UdeFineSTfiCK_INIT_SIZE100HdeFineSTACkTncREMENT10/UdeFine /Udefine /Udefine /ZttdeFineTRUE 1FALSE 0ERROR 0OUERFLOW 0typedef int int intstruct<*base;*top;stacksize;sqstack;定义栈顶和栈底都为int型,并且stacksize为血型。2 .构建一个空栈。intinitstack(sqstack*s)<s->base=(int*)malloc(STACK_INIT_SIZE*sizeoF(int);if(!s->base)e×it(0);s->top=s->base;s->stacksize«STACK_INIT_SIZE;return0;)构造一个空栈S建立一个空栈,但建立不成功是就强制退出,建立成功时就使栈顶和栈顶指向同一个点,并且分配预定长度的节给Stacksizeo3 .插入新的元素e为新的栈顶元素intpush(sqstack*s,inte)if(s->top-s->base)>=s->stacksize)<s->base=(int*)realloc(s->base,(s->stacksizeSTACKINCREMENT)*sizeoF(int);if(f(s->base)e×it(1);s->top三s->base*s->stacksize;s->stacksize+=STACKINCREMENT;>*s->top+=e;return0;>插入新的元素。为新的栈顶元素插入一个新的元素到栈里,如果长度超过栈的长度,则重新分配新的空间给SqStaCk。如果栈底部存在则发生错误,意外退出。然后让e插入成为新的栈顶元素。4 .判断栈是否为空栈。intStackempty(sqstack*s)iF(s->top=s->base)return1;elsereturn0;)若栈5为空栈,则返回1,否则返回0该函数用Stackempty表示,如果栈顶等于栈底,则栈为空栈,返回1,否则返回0.5 .取出栈顶元素intpop(sqstack*s,int*e)if(s->top=s->base)return1;*e=*s->top;return0;>若栈不为空,则删除S的栈顶元素,用。返回其值,返回OK,否则返回ERROR若栈为空,则返回1,若栈不为空,则让e指向S的栈顶元素,删除S的栈顶元素,用e返回其值。6,建立conversion函数uoidConuersion(intn)<sqstacks;inte;initstack(fts);Printf(,请输入一个十进制数:n");scanF("%d",ftn);while(n)push(6syn%8);n=n8;>Printfrn);Printf(,该数的八进制数为:n");while(!stackenpty(6s)pop(6s,6e);printf("¾d",e);printF(,n,);对于输入的任意一个非负十进制整数,打印出与其等值的八进制数定义一个空栈s,然后SCanf输入一个数,当该数不为0时,就执行PUSh函数和n=n8,如果n=0则跳出循环。然后当栈不为空时,将栈顶一个一个取出,得到的为原十进制数的八进制数。7.建立main函数。这里的main函数只要三句话就够了。定义n,和调用conversion函数,return0.

    注意事项

    本文(建立栈实现十进制转八进制 实验报告.docx)为本站会员(夺命阿水)主动上传,课桌文档仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知课桌文档(点击联系客服),我们立即给予删除!

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




    备案号:宁ICP备20000045号-1

    经营许可证:宁B2-20210002

    宁公网安备 64010402000986号

    课桌文档
    收起
    展开