数据结构栈和队列数据结栈和队列.pptVIP

  1. 1、本文档共32页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 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)进

文档评论(0)

skewguj + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档