- 1、本文档共32页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构栈和队列数据结栈和队列
2.引例实现 (1)将十进制整数转换为B进制整数函数 (2)将十进制纯小数转换为B进制纯小数函数 (3)主函数 引例分析与实现 int IntegerConversion(int N,int B) {//十进制整数N转换为等值的B进制整数 DataType x; LinkStack *S=(LinkStack *)malloc(sizeof(LinkStack)); if(S==NULL) { puts(空间申请失败!);return 0; } InitStack(S); if(number0) printf(-); if(N==0) printf(0); while(N) {//求N对应B进制数的各位数字,并将其进栈 if(Push(S,N%B)) N=N/B; } while(!StackEmpty(S)) {//栈非空时退栈输出 if(Pop(S,x)) if(x=10) printf(%c,x+87); else printf(%d,x); } return 1; } int DecimalConversion(double M,int B) {//十进制纯小数M转换为等值的B进制小数 DataType x; int j=1; CirQueue *Q=(CirQueue *)malloc(sizeof(CirQueue)); if(Q==NULL) { puts(空间申请失败!);return 0; } InitQueue(Q); if(M=E) printf(.); while(M=Ej++=QueueSize) {/*求M对应B进制数的各位数字,并将其入队,条件j++=QueueSize为避免出现无限小数产生的溢出*/ if(EnQueue(Q,(int)(M*B))) M=M*B-(int)(M*B); } while(!QueueEmpty(Q)) {//队非空时出队输出 if(DeQueue(Q,x)) if(x=10) printf(%c,x+87); else printf(%d,x); } printf(\n); return 1; } int main() { int N,B; //N为number的整数部分,B为待转换的进制 double M; //M为number小数部分 printf(请输入一个十进制数:); scanf(%lf,number); //输入任意的十进制数 N=(int)fabs(number); M=fabs(number)-N; printf(请输入需要转换的进制:); scanf(%d,B); printf(十进制数%lf转换为%d进制数为:\n,number,B); if(!IntegerConversion(N,B)) puts(整数转换出现异常!); if(!DecimalConversion(M,B)) puts(小数转换出现异常!); return 0; } 再 见 * * * * 国家教学资源库建设项目 单元3 栈和队列 * 数据结构 数据结构 教学目标 【知识目标】 掌握栈的定义及基本运算 掌握顺序栈、链栈基本运算的实现算法 掌握队列的定义及基本运算 掌握循环队列、链队列基本运算的实现算法 【能力目标】 具有恰当的选择栈或队列作为数据的逻辑结构,顺序栈(队列)、链栈(队列)作为数据的存储结构的能力 具有应用栈、队列解决实际问题的能力 引例描述——数制转换 将十进制数F转换为B进制数。输入任意一个十进制数,可以是整数,也可以是小数,输出对应进制的数。 演示执行 一、栈的定义及基本操作 1.定义 栈(Stack)是限制仅在表的一端进行插入和删除运算的线性表。向栈中插入元素称为进(入)栈,从栈中删除元素称为出(退)栈。 通常插入、删除的这一端称为栈顶(Stack Top),由于元素的进栈和退栈,使得栈顶的位置经常是变动的,因此需要用一个整型量Top指示栈顶的位置,通常称Top 为栈顶指针;另一端称为栈底。当表中没有元素时称为空栈,即Top=-1。 栈为后进先出(Last In First Out)的线性表,简称为LIFO表。 3.1 栈 知识储备 2.栈的基本运算 (1)置空栈:InitStack (S) 构造一个空栈S。 (2)判栈空:StackEmpty (S) 若S为空栈,则返回1,否则返回0。 (3)判栈满:StackFull (S) 若S为满栈,则返回1,否则返回0。 (4)进
您可能关注的文档
- 教育科研论文的撰写衢州茂外国语学校 王小未教育科研论文的撰写衢州华茂外国语学校 王小未.ppt
- 数字信号处理复习数字信处理复习.doc
- 数值计算方法学习报告数.doc
- 数字化校园财务管理信息统系统.ppt
- 数学(六上)及各章节计划.doc
- 教育部参赛_牛津小学英6AUnit5 On the farm_孙良婷教育部参赛_牛津小学英语.ppt
- 数学广角教学模式 王璐璐.doc
- 数列复习基本知识点及经结论总结 2数列复习基本知识点及经典结论总结 2.doc
- 数学必修一第三讲函数的调性与奇偶性数学必修一第三讲函数的单调性与奇偶性.ppt
- 数学教师业务考试试题数.doc
- 数格点 算面积数格点 面积.ppt
- 整合struts1+sring+hibernate框架完成简单的登录整合struts1+spring+hibernate框架完成简单的登录.doc
- 文书档案管理 2文书档管理 2.doc
- 数控加工编程与操作数控工编程与操作.ppt
- 文化武校六年级下册科学复习总复习.doc
- 整合struts与hiernate例子图文详解整合struts与hibernate例子图文详解.doc
- 文法学院+胡海春+应用法学人才培养之模式探索三批立项-课题申报表文法学院+胡海春+应用型法学人才培养之模式探索三批立项-课题申报表.doc
- 文学类文本阅读复习备考.ppt
- 文献综述格式要求文献综格式要求.doc
- 文秘职业生涯规划文秘职生涯规划.ppt
最近下载
- 01安吉县山洪灾害调查报告.pdf
- 方菱数控F162X(Ver2.3)F1620、F1621、F1627D、F1627S弧压调高器操作手册.pdf
- 中国地图可填色可编辑PPT模板.pptx VIP
- 《深度入局》 程序化数字户外媒体2025中国内地市场白皮书.pdf VIP
- 2025年高考生物复习新题之基因工程.pdf VIP
- 早产试题及答案.doc VIP
- 仁爱版七年级英语下册 动词过去式 复习课件(共28张PPT)(含音频+视频).pptx VIP
- 马丁·加德纳:啊哈!灵机一动(妙想奇思——趣味数学谜题60例).doc VIP
- (完整)小学一年级英语试卷 .pdf VIP
- 钳工基础知识培训资料.pptx VIP
文档评论(0)