欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    数据结构堆栈幻灯片.ppt

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

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

    数据结构堆栈幻灯片.ppt

    数据结构堆栈第1页,共38页,编辑于2022年,星期六4.1堆栈的概念及其运算堆栈的逻辑结构的逻辑结构堆栈:限定仅在表尾进行插入和删除操作的堆栈:限定仅在表尾进行插入和删除操作的线性表。线性表。空栈:不含任何数据元素的栈。空栈:不含任何数据元素的栈。允许插入和删除的一端称为栈顶,另一端称允许插入和删除的一端称为栈顶,另一端称为栈底。为栈底。(a1,a2,an)栈顶栈顶栈底栈底第2页,共38页,编辑于2022年,星期六abc入栈入栈出栈出栈栈底栈底栈顶栈顶插入:入栈、进栈、压栈插入:入栈、进栈、压栈插入:入栈、进栈、压栈插入:入栈、进栈、压栈删除:出栈、弹栈删除:出栈、弹栈删除:出栈、弹栈删除:出栈、弹栈栈顶栈顶栈顶栈顶栈的示意图栈的示意图4.1堆栈的概念及其运算栈的操作特性:栈的操作特性:后进先出后进先出第3页,共38页,编辑于2022年,星期六4.1堆栈的概念及其运算例:有三个元素按例:有三个元素按例:有三个元素按例:有三个元素按a a、b b、c c的次序依次进栈,且每个元素只的次序依次进栈,且每个元素只的次序依次进栈,且每个元素只的次序依次进栈,且每个元素只允许进一次栈,则可能的出栈序列有多少种?允许进一次栈,则可能的出栈序列有多少种?允许进一次栈,则可能的出栈序列有多少种?允许进一次栈,则可能的出栈序列有多少种?栈底栈底栈顶栈顶ab栈顶栈顶c栈顶栈顶情况情况1:出栈序列:出栈序列:c出栈序列:出栈序列:c、b出栈序列:出栈序列:c、b、a第4页,共38页,编辑于2022年,星期六例:有三个元素按例:有三个元素按例:有三个元素按例:有三个元素按a a、b b、c c的次序依次进栈,且每个元素只允的次序依次进栈,且每个元素只允的次序依次进栈,且每个元素只允的次序依次进栈,且每个元素只允许进一次栈,则可能的出栈序列有多少种?许进一次栈,则可能的出栈序列有多少种?许进一次栈,则可能的出栈序列有多少种?许进一次栈,则可能的出栈序列有多少种?栈底栈底栈顶栈顶ab栈顶栈顶情况情况2:出栈序列:出栈序列:b4.1堆栈的概念及其运算第5页,共38页,编辑于2022年,星期六栈底栈底a出栈序列:出栈序列:b出栈序列:出栈序列:b、c出栈序列:出栈序列:b、c、ac栈顶栈顶栈顶栈顶注意:注意:栈只是对表插入和删除操作的位置进行了限制,并没栈只是对表插入和删除操作的位置进行了限制,并没有限定插入和删除操作进行的时间。有限定插入和删除操作进行的时间。情况情况2:例:有三个元素按例:有三个元素按例:有三个元素按例:有三个元素按a a、b b、c c的次序依次进栈,且每个元素的次序依次进栈,且每个元素的次序依次进栈,且每个元素的次序依次进栈,且每个元素只允许进一次栈,则可能的出栈序列有多少种?只允许进一次栈,则可能的出栈序列有多少种?只允许进一次栈,则可能的出栈序列有多少种?只允许进一次栈,则可能的出栈序列有多少种?4.1堆栈的概念及其运算第6页,共38页,编辑于2022年,星期六堆栈的操作堆栈的操作堆栈的操作堆栈的操作Push(S,x)Push(S,x)Pop(S)Pop(S)Empty(S)Empty(S)Top(S)Top(S)Create(S)Create(S)4.1堆栈的概念及其运算第7页,共38页,编辑于2022年,星期六如何改造数组实现栈的顺序存储?如何改造数组实现栈的顺序存储?012345678a1确定用数组的哪一端表示栈底。确定用数组的哪一端表示栈底。附设指针附设指针top指示栈顶元素在数组中的位置。指示栈顶元素在数组中的位置。top4.2堆栈的顺序存储结构第8页,共38页,编辑于2022年,星期六出栈:出栈:top减减1进栈:进栈:top加加1栈空:栈空:top=-1 012345678a1topa2topa3top栈满:栈满:top=MAX_SIZE4.2堆栈的顺序存储结构第9页,共38页,编辑于2022年,星期六堆栈是否为空测试算法堆栈是否为空测试算法堆栈是否为空测试算法堆栈是否为空测试算法p70p70进栈算法进栈算法进栈算法进栈算法p71p71退栈算法退栈算法退栈算法退栈算法4.2堆栈的顺序存储结构第10页,共38页,编辑于2022年,星期六解决方案解决方案1:直接解决:为每个栈开辟一个数组空间。直接解决:为每个栈开辟一个数组空间。解决方案解决方案解决方案解决方案2 2:顺序栈单向延伸顺序栈单向延伸顺序栈单向延伸顺序栈单向延伸使用一个数组来存储两个栈使用一个数组来存储两个栈使用一个数组来存储两个栈使用一个数组来存储两个栈在一个程序中需要在一个程序中需要同时同时使用具有使用具有相同相同数据类型的数据类型的两个栈两个栈,如何顺序存储这两个栈?如何顺序存储这两个栈?会出现什么问题?如何解决?会出现什么问题?如何解决?4.2堆栈的顺序存储结构第11页,共38页,编辑于2022年,星期六两栈共享空间:两栈共享空间:两栈共享空间:两栈共享空间:使用一个数组来存储两个栈,让一个栈使用一个数组来存储两个栈,让一个栈使用一个数组来存储两个栈,让一个栈使用一个数组来存储两个栈,让一个栈的栈底为该数组的始端,另一个栈的栈底为该数组的末的栈底为该数组的始端,另一个栈的栈底为该数组的末的栈底为该数组的始端,另一个栈的栈底为该数组的末的栈底为该数组的始端,另一个栈的栈底为该数组的末端,两个栈从各自的端点向中间延伸。端,两个栈从各自的端点向中间延伸。端,两个栈从各自的端点向中间延伸。端,两个栈从各自的端点向中间延伸。4.2堆栈的顺序存储结构第12页,共38页,编辑于2022年,星期六栈栈栈栈1 1的底固定在下标为的底固定在下标为的底固定在下标为的底固定在下标为0 0的一端;的一端;的一端;的一端;栈栈栈栈2 2的底固定在下标为的底固定在下标为的底固定在下标为的底固定在下标为MaxSize-1MaxSize-1的一端。的一端。的一端。的一端。top1top1和和和和top2top2分别为栈分别为栈分别为栈分别为栈1 1和栈和栈和栈和栈2 2的栈顶指针;的栈顶指针;的栈顶指针;的栈顶指针;MaxSizeMaxSize为整个数组空间的大小(图中用为整个数组空间的大小(图中用为整个数组空间的大小(图中用为整个数组空间的大小(图中用S S表示);表示);表示);表示);a1a2aitop10 1 2 S-1top2bj b2b1栈栈1底底栈栈2底底4.2堆栈的顺序存储结构第13页,共38页,编辑于2022年,星期六top1=-1什么时候栈什么时候栈1为空?为空?a1a2aitop10 1 2 S-1top2bj b2b1top14.2堆栈的顺序存储结构第14页,共38页,编辑于2022年,星期六top1=-1什么时候栈什么时候栈1为空?为空?a1a2aitop10 1 2 S-1top2bj b2b1什么时候栈什么时候栈2为空?为空?top2top2=MaxSize4.2堆栈的顺序存储结构第15页,共38页,编辑于2022年,星期六top1=-1什么时候栈什么时候栈1为空?为空?a1a2aitop10 1 2 S-1top2bj b2b1什么时候栈什么时候栈2为空?为空?top2=MaxSize什么时候栈满?什么时候栈满?top2=top1+14.2堆栈的顺序存储结构第16页,共38页,编辑于2022年,星期六1.1.如果栈满,则抛出上溢异常;如果栈满,则抛出上溢异常;如果栈满,则抛出上溢异常;如果栈满,则抛出上溢异常;2.2.判断是插在栈判断是插在栈判断是插在栈判断是插在栈1 1还是栈还是栈还是栈还是栈2 2;2.12.1若在栈若在栈若在栈若在栈1 1插入,则插入,则插入,则插入,则2.1.1top12.1.1top1加加加加1;1;2.1.22.1.2在在在在top1top1处填入处填入处填入处填入x x;2.22.2若在栈若在栈若在栈若在栈2 2插入,则插入,则插入,则插入,则2.2.1top22.2.1top2减减减减1;1;2.2.22.2.2在在在在top2top2处填入处填入处填入处填入x x;操作接口:操作接口:操作接口:操作接口:voidPush(inti,Tx)voidPush(inti,Tx);4.2堆栈的顺序存储结构第17页,共38页,编辑于2022年,星期六1.1.若是在栈若是在栈若是在栈若是在栈1 1删除,则删除,则删除,则删除,则1.11.1若栈若栈若栈若栈1 1为空栈,抛出下溢异常;为空栈,抛出下溢异常;为空栈,抛出下溢异常;为空栈,抛出下溢异常;1.21.2删除并返回栈删除并返回栈删除并返回栈删除并返回栈1 1的栈顶元素;的栈顶元素;的栈顶元素;的栈顶元素;2.2.若是在栈若是在栈若是在栈若是在栈2 2删除,则删除,则删除,则删除,则2.12.1若栈若栈若栈若栈2 2为空栈,抛出下溢异常;为空栈,抛出下溢异常;为空栈,抛出下溢异常;为空栈,抛出下溢异常;2.22.2删除并返回栈删除并返回栈删除并返回栈删除并返回栈2 2的栈顶元素;的栈顶元素;的栈顶元素;的栈顶元素;操作接口:操作接口:操作接口:操作接口:TPop(inti)TPop(inti);4.2堆栈的顺序存储结构第18页,共38页,编辑于2022年,星期六heada1a2anai链栈需要加头结点吗?链栈需要加头结点吗?如何改造链表实现栈的链接存储?如何改造链表实现栈的链接存储?将哪一端作为栈顶?将哪一端作为栈顶?将链头作为栈顶,方便操作。将链头作为栈顶,方便操作。将链头作为栈顶,方便操作。将链头作为栈顶,方便操作。链栈不需要附设头结点。链栈不需要附设头结点。链栈不需要附设头结点。链栈不需要附设头结点。4.3堆栈的链式存储结构第19页,共38页,编辑于2022年,星期六栈顶栈顶栈底栈底链栈:链栈:链栈:链栈:栈的链接存储结构栈的链接存储结构栈的链接存储结构栈的链接存储结构topanan-1a1heada1a2anai两种示意图在内存中两种示意图在内存中两种示意图在内存中两种示意图在内存中对应同一种状态对应同一种状态对应同一种状态对应同一种状态topa1an-1an栈顶栈顶栈底栈底4.3堆栈的链式存储结构第20页,共38页,编辑于2022年,星期六4.3堆栈的链式存储结构 入栈:入栈:入栈:入栈:p75p75 出栈:出栈:出栈:出栈:p75p75操作接口:操作接口:操作接口:操作接口:第21页,共38页,编辑于2022年,星期六4.3堆栈的链式存储结构顺序栈和链栈的比较顺序栈和链栈的比较顺序栈和链栈的比较顺序栈和链栈的比较 时间性能:相同,都是常数时间时间性能:相同,都是常数时间时间性能:相同,都是常数时间时间性能:相同,都是常数时间O(1)O(1)。空间性能:空间性能:空间性能:空间性能:顺序栈:有元素个数的限制和空间浪费的问题。顺序栈:有元素个数的限制和空间浪费的问题。顺序栈:有元素个数的限制和空间浪费的问题。顺序栈:有元素个数的限制和空间浪费的问题。链栈:没有栈满的问题,只有当内存没有可用空间时才会出链栈:没有栈满的问题,只有当内存没有可用空间时才会出链栈:没有栈满的问题,只有当内存没有可用空间时才会出链栈:没有栈满的问题,只有当内存没有可用空间时才会出现栈满,但是每个元素都需要一个指针域,从而产生了结构现栈满,但是每个元素都需要一个指针域,从而产生了结构现栈满,但是每个元素都需要一个指针域,从而产生了结构现栈满,但是每个元素都需要一个指针域,从而产生了结构性开销。性开销。性开销。性开销。总之,当栈的使用过程中元素个数变化较大时,用总之,当栈的使用过程中元素个数变化较大时,用总之,当栈的使用过程中元素个数变化较大时,用总之,当栈的使用过程中元素个数变化较大时,用链栈是适宜的,反之,应该采用顺序栈。链栈是适宜的,反之,应该采用顺序栈。链栈是适宜的,反之,应该采用顺序栈。链栈是适宜的,反之,应该采用顺序栈。第22页,共38页,编辑于2022年,星期六 1 1 递归的定义递归的定义递归的定义递归的定义 子程序(或函数)直接调用自己或通过一系列调用语子程序(或函数)直接调用自己或通过一系列调用语子程序(或函数)直接调用自己或通过一系列调用语子程序(或函数)直接调用自己或通过一系列调用语句间接调用自己,是一种描述问题和解决问题的基本句间接调用自己,是一种描述问题和解决问题的基本句间接调用自己,是一种描述问题和解决问题的基本句间接调用自己,是一种描述问题和解决问题的基本方法。方法。方法。方法。2 2 递归的基本思想递归的基本思想递归的基本思想递归的基本思想 问题分解:把一个不能或不好解决的大问题转化为一个或几问题分解:把一个不能或不好解决的大问题转化为一个或几问题分解:把一个不能或不好解决的大问题转化为一个或几问题分解:把一个不能或不好解决的大问题转化为一个或几个小问题,再把这些小问题进一步分解成更小的小问题,直个小问题,再把这些小问题进一步分解成更小的小问题,直个小问题,再把这些小问题进一步分解成更小的小问题,直个小问题,再把这些小问题进一步分解成更小的小问题,直至每个小问题都可以直接解决。至每个小问题都可以直接解决。至每个小问题都可以直接解决。至每个小问题都可以直接解决。4.4堆栈的应用递归第23页,共38页,编辑于2022年,星期六3 递归的要素递归的要素递归边界条件:确定递归到何时终止,也称递归边界条件:确定递归到何时终止,也称为递归出口;为递归出口;递归模式:大问题是如何分解为小问题的,递归模式:大问题是如何分解为小问题的,也称为递归体。也称为递归体。4.4堆栈的应用递归第24页,共38页,编辑于2022年,星期六4.4堆栈的应用递归递归算法递归算法递归算法递归算法intfact(intn)intfact(intn)if(n=0)return1;if(n=0)return1;elsereturnn*fact(n-1);elsereturnn*fact(n-1);-*=时时当当时时当当)!1(1!n1n1nnn例例例例1 1 1 1 阶乘函数阶乘函数阶乘函数阶乘函数第25页,共38页,编辑于2022年,星期六4.4堆栈的应用递归递归的经典问题递归的经典问题汉诺塔问题汉诺塔问题 在世界刚被创建的时候有一座钻石宝塔(塔在世界刚被创建的时候有一座钻石宝塔(塔A),其上有),其上有64个金碟。所有碟子按从大到个金碟。所有碟子按从大到小的次序从塔底堆放至塔顶。紧挨着这座塔小的次序从塔底堆放至塔顶。紧挨着这座塔有另外两个钻石宝塔(塔有另外两个钻石宝塔(塔B和塔和塔C)。从世)。从世界创始之日起,婆罗门的牧师们就一直在试界创始之日起,婆罗门的牧师们就一直在试图把塔图把塔A上的碟子移动到塔上的碟子移动到塔C上去,其间借上去,其间借助于塔助于塔B的帮助。每次只能移动一个碟子,的帮助。每次只能移动一个碟子,任何时候都不能把一个碟子放在比它小的碟任何时候都不能把一个碟子放在比它小的碟子上面。当牧师们完成任务时,世界末日也子上面。当牧师们完成任务时,世界末日也就到了。就到了。第26页,共38页,编辑于2022年,星期六4.4堆栈的应用递归汉诺塔问题的递归求解汉诺塔问题的递归求解:如果如果 n=1,则将这一个盘子直接从,则将这一个盘子直接从 塔塔A移移到塔到塔 C 上。否则,执行以下三步:上。否则,执行以下三步:将塔将塔A上的上的n-1个碟子借助塔个碟子借助塔C先移到塔先移到塔B上;上;把塔把塔A上剩下的一个碟子移到塔上剩下的一个碟子移到塔C上;上;将将n-1个碟子从塔个碟子从塔B借助于塔借助于塔A移到塔移到塔C上。上。第27页,共38页,编辑于2022年,星期六4.4堆栈的应用递归第28页,共38页,编辑于2022年,星期六4.4堆栈的应用递归voidHanoivoidHanoi(intn,charA,charB,charCintn,charA,charB,charC)ifif(n=1n=1)MoveMove(A,CA,C);elseelseHanoiHanoi(n n-1,A,C,B1,A,C,B);MoveMove(A,CA,C);HanoiHanoi(n n-1,B,A,C1,B,A,C);第29页,共38页,编辑于2022年,星期六4.4堆栈的应用递归 递归函数的内部执行过程递归函数的内部执行过程递归函数的内部执行过程递归函数的内部执行过程 运行开始时,首先为递归调用建立一个工作栈,其结构运行开始时,首先为递归调用建立一个工作栈,其结构运行开始时,首先为递归调用建立一个工作栈,其结构运行开始时,首先为递归调用建立一个工作栈,其结构包括值参、局部变量和返回地址;包括值参、局部变量和返回地址;包括值参、局部变量和返回地址;包括值参、局部变量和返回地址;每次执行递归调用之前,把递归函数的值参和局部每次执行递归调用之前,把递归函数的值参和局部每次执行递归调用之前,把递归函数的值参和局部每次执行递归调用之前,把递归函数的值参和局部变量的当前值以及调用后的返回地址压栈;变量的当前值以及调用后的返回地址压栈;变量的当前值以及调用后的返回地址压栈;变量的当前值以及调用后的返回地址压栈;每次递归调用结束后,将栈顶元素出栈,使相应的值参和每次递归调用结束后,将栈顶元素出栈,使相应的值参和每次递归调用结束后,将栈顶元素出栈,使相应的值参和每次递归调用结束后,将栈顶元素出栈,使相应的值参和局部变量恢复为调用前的值,然后转向返回地址指定的位置局部变量恢复为调用前的值,然后转向返回地址指定的位置局部变量恢复为调用前的值,然后转向返回地址指定的位置局部变量恢复为调用前的值,然后转向返回地址指定的位置继续执行。继续执行。继续执行。继续执行。第30页,共38页,编辑于2022年,星期六Hanio(3,A,B,C)Hanio(2,A,C,B)Hanio(1,A,B,C)Move(A,C)Move(A,B)Hanio(1,C,A,B)Hanio(1,A,B,C)Hanio(2,A,C,B)Move(C,B)Hanio(1,C,A,B)Move(A,C)Hanio(2,B,A,C)Hanio(1,B,C,A)Move(B,C)Hanio(1,A,B,C)Hanio(1,B,C,A)Move(A,C)Hanio(2,B,A,C)Move(B,A)Hanio(1,A,B,C)结束结束第31页,共38页,编辑于2022年,星期六4.4堆栈的应用表达式求值表达式求值中缀表达式中缀表达式后缀表达式后缀表达式后缀表达式特点后缀表达式特点后缀表达式中不出现括号后缀表达式中不出现括号后缀表达式与中缀表达式的运算对象的先后次序后缀表达式与中缀表达式的运算对象的先后次序相同,只是所读到的运算符的先后次序可能有所相同,只是所读到的运算符的先后次序可能有所改变改变第32页,共38页,编辑于2022年,星期六4.4堆栈的应用表达式求值表达式求值后缀表达式实例后缀表达式实例(1)ABCE/-E*+对应中缀表达式对应中缀表达式对应中缀表达式对应中缀表达式 A+(B-C/D)*E A+(B-C/D)*E(2)ABCD/F*-E*+X+对应中缀表达式对应中缀表达式对应中缀表达式对应中缀表达式A+(B-C/D*F)*E+XA+(B-C/D*F)*E+X 第33页,共38页,编辑于2022年,星期六4.4堆栈的应用后缀表达式求值后缀表达式求值后缀表达式计算算法:后缀表达式计算算法:后缀表达式计算算法:后缀表达式计算算法:Procedure EVAL(E)/EProcedure EVAL(E)/E为后缀表达式为后缀表达式为后缀表达式为后缀表达式toptop0 0looploopx x NEXT_TOKEN(E)NEXT_TOKEN(E)casecase:x=“#”:x=“#”:returnreturn:x=:x=运算对象运算对象运算对象运算对象:call PUSH(STACK,M,top,x)call PUSH(STACK,M,top,x):else:else:从堆栈中取出相应的运算对象进行由从堆栈中取出相应的运算对象进行由从堆栈中取出相应的运算对象进行由从堆栈中取出相应的运算对象进行由x x执行的运算执行的运算执行的运算执行的运算并将结果入栈并将结果入栈并将结果入栈并将结果入栈endendforeverforeverendend第34页,共38页,编辑于2022年,星期六4.4堆栈的应用中缀表达式转换中缀表达式转换算法思想算法思想p81-82关键点:关键点:运算符堆栈运算符堆栈运算符优先关系表运算符优先关系表第35页,共38页,编辑于2022年,星期六4.4堆栈的应用中缀表达式转换中缀表达式转换运算优先级运算优先级()#(#1 dowhile top1 doprint(STACKtop)print(STACKtop)/输出栈顶运算符输出栈顶运算符输出栈顶运算符输出栈顶运算符call POP(STATCK,top)/call POP(STATCK,top)/退栈退栈退栈退栈endendprint(“#”);print(“#”);returnreturn:x:x是运算对象是运算对象是运算对象是运算对象:print(x)print(x)/直接输出运算对象直接输出运算对象直接输出运算对象直接输出运算对象endendforeverforeverendend第37页,共38页,编辑于2022年,星期六4.4堆栈的应用中缀表达式转换中缀表达式转换:x=“:x=“)”:”:while STACKtop”(“dowhile STACKtop”(“doprint(STATCKtop)print(STATCKtop)call POP(STACK,top)call POP(STACK,top)endendtop top top-1/top-1/放弃当前读到的放弃当前读到的放弃当前读到的放弃当前读到的”)”)”,并且栈顶,并且栈顶,并且栈顶,并且栈顶“(”“(”退栈退栈退栈退栈:else:else:while ISP(STACKtop=ICP(x)dowhile ISP(STACKtop=ICP(x)doprint(STACKtop)print(STACKtop)call POP(STACK,top)call POP(STACK,top)endendcall PUSH(STACK,top,x)call PUSH(STACK,top,x)/运算符进栈运算符进栈运算符进栈运算符进栈endendforeverforeverendend第38页,共38页,编辑于2022年,星期六

    注意事项

    本文(数据结构堆栈幻灯片.ppt)为本站会员(石***)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

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




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

    本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开