数据结构(C语言版) 查找表 详细举例介绍.ppt_第1页
数据结构(C语言版) 查找表 详细举例介绍.ppt_第2页
数据结构(C语言版) 查找表 详细举例介绍.ppt_第3页
数据结构(C语言版) 查找表 详细举例介绍.ppt_第4页
数据结构(C语言版) 查找表 详细举例介绍.ppt_第5页
已阅读5页,还剩164页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

第九章查找表,查找表是由同一类型的数据元素(或记录)构成的集合。,由于“集合”中的数据元素之间存在着松散的关系,因此查找表是一种应用灵便的结构。,何谓查找表?,对查找表经常进行的操作:,查询某个“特定的”数据元素是否在查找表中;检索某个“特定的”数据元素的各种属性;在查找表中插入一个数据元素;从查找表中删去某个数据元素。,仅作查询和检索操作的查找表。,静态查找表,有时在查询之后,还需要将“查询”结果为“不在查找表中”的数据元素插入到查找表中;或者,从查找表中删除其“查询”结果为“在查找表中”的数据元素。,动态查找表,查找表可分为两类:,是数据元素(或记录)中某个数据项的值,用以标识(识别)一个数据元素(或记录)。,关键字,若此关键字可以识别唯一的一个记录,则称之谓“主关键字”。,若此关键字能识别若干记录,则称之谓“次关键字”。,根据给定的某个值,在查找表中确定一个其关键字等于给定值的数据元素或(记录),查找,若查找表中存在这样一个记录,则称“查找成功”,查找结果:给出整个记录的信息,或指示该记录在查找表中的位置;否则称“查找不成功”,查找结果:给出“空记录”或“空指针”。,由于查找表中的数据元素之间不存在明显的组织规律,因此不便于查找。为了提高查找的效率,需要在查找表中的元素之间人为地附加某种确定的关系,换句话说,用另外一种结构来表示查找表。,查找的方法取决于查找表的结构。,如何进行查找?,9.1静态查找表,9.2动态查找树表,9.3哈希表,9.1静态查找表,数据对象D:,数据关系R:,D是具有相同特性的数据元素的集合。每个数据元素含有类型相同的关键字,可唯一标识数据元素。,数据元素同属一个集合。,ADTStaticSearchTable,Create(,Destroy(,Search(ST,key);,Traverse(ST,Visit();,基本操作P:,next,ADTStaticSearchTable,构造一个含n个数据元素的静态查找表ST。,Create(,操作结果:,销毁表ST。,Destroy(,初始条件:操作结果:,静态查找表ST存在;,若ST中存在其关键字等于key的数据元素,则函数值为该元素的值或在表中的位置,否则为“空”。,Search(ST,key);,初始条件:操作结果:,静态查找表ST存在,key为和查找表中元素的关键字类型相同的给定值;,按某种次序对ST的每个元素调用函数Visit()一次且仅一次,一旦Visit()失败,则操作失败。,Traverse(ST,Visit();,初始条件:操作结果:,静态查找表ST存在,Visit是对元素操作的应用函数;,typedefstruct/数据元素存储空间基址,建表时/按实际长度分配,0号单元留空intlength;/表的长度SSTable;,假设静态查找表的顺序存储结构为,ElemType*elem;,数据元素类型的定义为:,typedefstructkeyTypekey;/关键字域/其它属性域ElemType;,TElemType;,一、顺序查找表,二、有序查找表,三、静态查找树表,四、索引顺序表,以顺序表或线性链表表示静态查找表,一、顺序查找表,ST.elem,回顾顺序表的查找过程:,假设给定值e=64,要求ST.elemk=e,问:k=?,k,k,intLocation(SqListL,ElemType,ST.elem,i,ST.elem,i,60,i,key=64,key=60,i,64,intSearch_Seq(SSTableST,KeyTypekey)/在顺序表ST中顺序查找其关键字等于/key的数据元素。若找到,则函数值为/该元素在表中的位置,否则为0。ST.elem0.key=key;/“哨兵”for(i=ST.length;ST.elemi.key!=key;-i);/从后往前找returni;/找不到时,i为0,定义:查找算法的平均查找长度(AverageSearchLength)为确定记录在查找表中的位置,需和给定值进行比较的关键字个数的期望值其中:n为表长,Pi为查找表中第i个记录的概率,且Ci为找到该记录时,曾和给定值比较过的关键字的个数。,分析顺序查找的时间性能。,在等概率查找的情况下,顺序表查找的平均查找长度为:,对顺序表而言,Ci=n-i+1,ASL=nP1+(n-1)P2+2Pn-1+Pn,若查找概率无法事先测定,则查找过程采取的改进办法是,在每次查找之后,将刚刚查找到的记录直接移至表尾的位置上。,在不等概率查找的情况下,ASLss在PnPn-1P2P1时取极小值,上述顺序查找表的查找算法简单,但平均查找长度较大,特别不适用于表长较大的查找表。,若以有序表表示静态查找表,则查找过程可以基于“折半”进行。,二、有序查找表,ST.elem,ST.length,例如:key=64的查找过程如下,low,high,mid,low,mid,high,mid,low指示查找区间的下界;high指示查找区间的上界;mid=(low+high)/2。,intSearch_Bin(SSTableST,KeyTypekey)low=1;high=ST.length;/置区间初值while(low50时,可得近似结果,一般情况下,表长为n的折半查找的判定树的深度和含有n个结点的完全二叉树的深度相同。,关键字:ABCDEPi:0.20.30.050.30.15Ci:23123,在不等概率查找的情况下,折半查找不是有序表最好的查找方法,例如:,此时ASL=20.2+30.3+10.05+20.3+30.15=2.4,若改变Ci的值21323,则ASL=20.2+10.3+30.05+20.3+30.15=1.9,三、静态查找树表,使达最小的判定树称为最优二叉树,其中:,定义:,为计算方便,令wi=pi选择二叉树的根结点,使达最小,介绍一种次优二叉树的构造方法:,为便于计算,引入累计权值和并设wl-1=0和swl-1=0,则推导可得,0,2,3,8,11,15,18,23,例如:,l,h,21,18,12,4,3,10,18,h,9,6,0,8,E,C,2,1,A,h,5,3,l,h,G,3,0,1,3,E,C,G,A,B,D,F,所得次优二叉树如下所示:,查找比较“总次数”=32+41+25+33+14+33+25=52,查找比较“总次数”=32+21+35+13+34+23+35=59,和折半查找相比较,D,B,A,C,F,E,G,StatusSecondOptimal(BiTree/生成结点,构造次优二叉树的算法,CONTINUE,if(i=low)T-lchild=NULL;/左子树空elseSecondOptimal(T-lchild,R,sw,low,i-1);/构造左子树if(i=high)T-rchild=NULL;/右子树空elseSecondOptimal(T-rchild,R,sw,i+1,high);/构造右子树returnOK;/SecondOptimal,次优查找树采用二叉链表的存储结构,StatusCreateSOSTre(SOSTree/CreatSOSTree,四、索引顺序表,以索引顺序表表示静态查找表,search操作可用分块查找来实现。分块查找又称索引顺序查找,这是顺序查找的一种改进方法。在此查找方法中,除表本身以外,尚需建立一个“索引表”。,例如,表中含有18个元素,可分成三个子表。对每个子表(或称块)建立一个索引项,其中包括两项内容:关键字项(其值为该子表内的最大关键字)和项指针(指示该子表的第一个元素在表中位置)。,索引表,最大关键字,起始地址,索引表按关键字有序,故表或者有序,或者分块有序。所谓“分块有序”是指一个子表中所有元素的关键字均大于前一个子表的最大关键字。,索引顺序表的查找过程:,1)由索引确定记录所在区间;,2)在顺序表的某个区间内进行查找。,注意:索引可以根据查找表的特点来构造。,可见,索引顺序查找的过程也是一个“缩小区间”的查找过程。,索引顺序查找的平均查找长度=查找“索引”的平均查找长度+查找“顺序表”的平均查找长度,9.2动态查找树表,(n)(1)(n)(1)(nlogn),综合上一节讨论的几种查找表的特性:,查找插入删除,无序顺序表无序线性链表有序顺序表有序线性链表静态查找树表,(n)(n)(logn)(n)(logn),(1)(1)(n)(1)(nlogn),1)从查找性能看,最好情况能达(logn),此时要求表有序;,2)从插入和删除的性能看,最好情况能达(1),此时要求存储结构是链表。,可得如下结论:,ADTDynamicSearchTable,抽象数据类型动态查找表的定义如下:,数据对象D:数据关系R:,数据元素同属一个集合。,D是具有相同特性的数据元素的集合。每个数据元素含有类型相同的关键字,可唯一标识数据元素。,InitDSTable(,InsertDSTable(,DeleteDSTable(,TraverseDSTable(DT,Visit();,next,ADTDynamicSearchTable,操作结果:,构造一个空的动态查找表DT。,InitDSTable(,销毁动态查找表DT。,DestroyDSTable(,初始条件:操作结果:,动态查找表DT存在;,若DT中存在其关键字等于key的数据元素,则函数值为该元素的值或在表中的位置,否则为“空”。,SearchDSTable(DT,key);,初始条件:操作结果:,动态查找表DT存在,key为和关键字类型相同的给定值;,动态查找表DT存在,e为待插入的数据元素;,InsertDSTable(,初始条件:操作结果:,若DT中不存在其关键字等于e.key的数据元素,则插入e到DT。,动态查找表DT存在,key为和关键字类型相同的给定值;,DeleteDSTable(,初始条件:操作结果:,若DT中存在其关键字等于key的数据元素,则删除之。,动态查找表DT存在,Visit是对结点操作的应用函数;,TraverseDSTable(DT,Visit();,初始条件:操作结果:,按某种次序对DT的每个结点调用函数Visit()一次且至多一次。一旦Visit()失败,则操作失败。,一、二叉排序树(二叉查找树),二、二叉平衡树,三、B-树,四、B+树,五、键树,1定义,2查找算法,3插入算法,4删除算法,5查找性能的分析,一、二叉排序树(二叉查找树),(1)若它的左子树不空,则左子树上所有结点的值均小于根结点的值;,二叉排序树或者是一棵空树;或者是具有如下特性的二叉树:,(3)它的左、右子树也都分别是二叉排序树。,(2)若它的右子树不空,则右子树上所有结点的值均大于根结点的值;,1定义:,50,30,80,20,90,10,85,40,35,25,23,88,例如:,是二叉排序树,66,不,通常,取二叉链表作为二叉排序树的存储结构,typedefstructBiTNode/结点结构structBiTNode*lchild,*rchild;/左右孩子指针BiTNode,*BiTree;,TElemTypedata;,2二叉排序树的查找算法:,1)若给定值等于根结点的关键字,则查找成功;2)若给定值小于根结点的关键字,则继续在左子树上进行查找;3)若给定值大于根结点的关键字,则继续在右子树上进行查找。,否则,若二叉排序树为空,则查找不成功;,50,30,80,20,90,85,40,35,88,32,例如:,二叉排序树,查找关键字,=50,50,50,35,50,30,40,35,50,90,50,80,90,95,从上述查找过程可见,,在查找过程中,生成了一条查找路径:,从根结点出发,沿着左分支或右分支逐层向下直至关键字等于给定值的结点;,或者,从根结点出发,沿着左分支或右分支逐层向下直至指针指向空树为止。,查找成功,查找不成功,算法描述如下:,StatusSearchBST(BiTreeT,KeyTypekey,BiTreef,BiTree/SearchBST,否则表明查找不成功,返回/指针p指向查找路径上访问的最后一个结点,/并返回函数值为FALSE,指针f指向当前访问/的结点的双亲,其初始调用值为NULL,if(!T)elseif(EQ(key,T-data.key)elseif(LT(key,T-data.key)else,p=f;returnFALSE;/查找不成功,p=T;returnTRUE;/查找成功,SearchBST(T-lchild,key,T,p);/在左子树中继续查找,SearchBST(T-rchild,key,T,p);/在右子树中继续查找,30,20,10,40,35,25,23,f,T,设key=48,f,T,f,T,22,p,f,T,f,T,T,T,T,f,f,f,p,根据动态查找表的定义,“插入”操作在查找不成功时才进行;,3二叉排序树的插入算法,若二叉排序树为空树,则新插入的结点为新的根结点;否则,新插入的结点必为一个新的叶子结点,其插入位置由查找过程得到。,StatusInsertBST(BiTree/InsertBST,s=(BiTree)malloc(sizeof(BiTNode);/为新结点分配空间s-data=e;s-lchild=s-rchild=NULL;,if(!p)T=s;/插入s为新的根结点,elseif(LT(e.key,p-data.key)p-lchild=s;/插入*s为*p的左孩子elsep-rchild=s;/插入*s为*p的右孩子,returnTRUE;/插入成功,(1)被删除的结点是叶子;(2)被删除的结点只有左子树或者只有右子树;(3)被删除的结点既有左子树,也有右子树。,可分三种情况讨论:,和插入相反,删除在查找成功之后进行,并且要求在删除二叉排序树上某个结点之后,仍然保持二叉排序树的特性。,4二叉排序树的删除算法,50,30,80,20,90,85,40,35,88,32,(1)被删除的结点是叶子结点,例如:,被删关键字=20,88,其双亲结点中相应指针域的值改为“空”,50,30,80,20,90,85,40,35,88,32,(2)被删的结点只有左子树或只有右子树,其双亲结点的相应指针域的值改为“指向被删除结点的左子树或右子树”。,被删关键字=40,80,50,30,80,20,90,85,40,35,88,32,(3)被删除的结点既有左子树,也有右子树,40,40,以其前驱替代之,然后再删除该前驱结点,被删结点,前驱结点,被删关键字=50,以中序遍历排好,20-30-32-35-40-50-80-85-88-90,StatusDeleteBST(BiTree/不存在关键字等于key的数据元素else/DeleteBST,算法描述如下:,if(EQ(key,T-data.key)/找到关键字等于key的数据元素elseif(LT(key,T-data.key)else,Delete(T);returnTRUE;,DeleteBST(T-lchild,key);/继续在左子树中进行查找,DeleteBST(T-rchild,key);/继续在右子树中进行查找,voidDelete(BiTreep=p-lchild;free(q);,p,p,此处p应该换为f的左孩子或右,根据p为f左还是右而定,/左子树为空树只需重接它的右子树,q=p;p=p-rchild;free(q);,p,p,q=p;s=p-lchild;while(!s-rchild)q=s;s=s-rchild;/s指向被删结点的前驱,/左右子树均不空,p-data=s-data;if(q!=p)q-rchild=s-lchild;elseq-lchild=s-lchild;/重接*q的左子树free(s);,p,q,s,对于每一棵特定的二叉排序树,均可按照平均查找长度的定义来求它的ASL值,显然,由值相同的n个关键字,构造所得的不同形态的各棵二叉排序树的平均查找长度的值不同,甚至可能差别很大。,5查找性能的分析,由关键字序列3,1,2,5,4构造而得的二叉排序树,由关键字序列1,2,3,4,5构造而得的二叉排序树,,例如:,2,1,3,4,5,3,5,4,1,2,ASL=(1+2+3+4+5)/5=3,ASL=(1+2+3+2+3)/5=2.2,下面讨论平均情况:,不失一般性,假设长度为n的序列中有k个关键字小于第一个关键字,则必有n-k-1个关键字大于第一个关键字,由它构造的二叉排序树,n-k-1,k,的平均查找长度是n和k的函数,P(n,k)(0kn-1),假设n个关键字可能出现的n!种排列的可能性相同,则含n个关键字的二叉排序树的平均查找长度,在等概率查找的情况下,,由此,可类似于解差分方程,此递归方程有解:,何谓“二叉平衡树”?,二叉平衡树的查找性能分析,如何构造“二叉平衡树”,二、二叉平衡树,二叉平衡树是二叉查找树的另一种形式,其特点为:,树中每个结点的左、右子树深度之差的绝对值不大于1。,例如:,5,4,8,2,5,4,8,2,1,是平衡树,不是平衡树,构造二叉平衡(查找)树的方法是:在插入过程中,采用平衡旋转技术。,例如:依次插入的关键字为5,4,2,8,6,9,5,4,2,4,2,5,8,6,6,5,8,4,2,向右旋转一次,先向右旋转再向左旋转,4,2,6,5,8,9,6,4,2,8,9,5,向左旋转一次,继续插入关键字9,在平衡树上进行查找的过程和二叉排序树相同,因此,查找过程中和给定值进行比较的关键字的个数不超过平衡树的深度。,平衡树的查找性能分析:,问:含n个关键字的二叉平衡树可能达到的最大深度是多少?,n=0,空树,最大深度为0,n=1,最大深度为1,n=2,最大深度为2,n=4,最大深度为3,n=7,最大深度为4,先看几个具体情况:,反过来问,深度为h的二叉平衡树中所含结点的最小值Nh是多少?,h=0,N0=0,h=1,h=2,h=3,一般情况下,,N1=1,N2=2,N3=4,Nh=Nh-1+Nh-2+1,利用归纳法可证得,,Nh=Fh+2-1,因此,在二叉平衡树上进行查找时,查找过程中和给定值进行比较的关键字的个数和log(n)相当。,由此推得,深度为h的二叉平衡树中所含结点的最小值Nh=h+2/5-1,反之,含有n个结点的二叉平衡树能达到的最大深度hn=log(5(n+1)-2,1定义,2查找过程,3插入操作,4删除操作,5查找性能的分析,三、B-树,1B-树的定义,B-树是一种平衡的多路查找树:,在m阶的B-树上,每个非终端结点可能含有:n个关键字Ki(1in)nmn个指向记录的指针Di(1in)n+1个指向子树的指针Ai(0in);,多叉树的特性,typedefstructBTNodeintkeynum;/结点中关键字个数,结点大小structBTNode*parent;/指向双亲结点的指针KeyTypekeym+1;/关键字(0号单元不用)structBTNode*ptrm+1;/子树指针向量Record*recptrm+1;/记录指针向量BTNode,*BTree;/B树结点和B树的类型,B-树结构的C语言描述如下:,非叶结点中的多个关键字均自小至大有序排列,即:K1K2first;i=0;,若(p,若(p,若(p,3.Trie树,以多重链表作存储结构实现的键树,结点结构:,分支结点,叶子结点,指向记录的指针,012345242526,关键字,指向下层结点的指针每个域对应一个“字母”,01(A)345(E)9(I)26,8(H),4(D)19(S)22(V)018(R)7(G)19,05(E),T,HAD,HAS,HAVE,HE,HER,HERE,HIGH,HIS,叶子结点,分支结点,指向记录的指针,typedefstructTrieNodeNodeKindkind;/结点类型unionstructKeyTypeK;Record*infoptrlf;/叶子结点(关键字和指向记录的指针)structTrieNode*ptr27;intnumbh;/分支结点(27个指向下一层结点的指针)TrieNode,*TrieTree;/键树类型,结点结构的C语言描述:,在Trie树中查找记录的过程:,假设:T为指向Trie树根结点的指针,K.ch0.K.num-1为待查关键字(给定值)。,则查找过程中的基本操作为:搜索和对应字母相应的指针:若p不空,且p所指为分支结点,则p=p-bh.Ptrord(K.Chi);(其中:0iK.num-1),初始状态:p=T;i=0;,若(p其中,ord为求字符在字母表中序号的函数,若(p,从这个例子可见,,2)由于哈希函数是一个压缩映象,因此,在一般情况下,很容易产生“冲突”现象,即:key1key2,而f(key1)=f(key2)。,3)很难找到一个不产生冲突的哈希函数。一般情况下,只能选择恰当的哈希函数,使冲突尽可能少地产生。,因此,在构造这种特殊的“查找表”时,除了需要选择一个“好”(尽可能少产生冲突)的哈希函数之外;还需要找到一种“处理冲突”的方法。,哈希表的定义:,根据设定的哈希函数H(key)和所选中的处理冲突的方法,将一组关键字映象到一个有限的、地址连续的地址集(区间)上,并以关键字在地址集中的“象”作为相应记录在表中的存储位置,如此构造所得的查找表称之为“哈希表”。,对数字的关键字可有下列构造方法:,若是非数字关键字,则需先对其进行数字化处理。,1.直接定址法,3.平方取中法,5.除留余数法,4.折叠法,6.随机数法,2.数字分析法,二、构造哈希函数的方法,哈希函数为关键字的线性函数H(key)=key或者H(key)=akey+b,1.直接定址法,此法仅适合于:地址集合的大小=关键字集合的大小,此方法仅适合于:能预先估计出全体关键字的每一位上各种数字出现的频度。,2.数字分析法,假设关键字集合中的每个关键字都是由s位数字组成(u1,u2,us),分析关键字集中的全体,并从中提取分布均匀的若干位或它们的组合作为地址。,以关键字的平方值的中间几位作为存储地址。求“关键字的平方值”的目的是“扩大差别”,同时平方值的中间各位又能受到整个关键字中各位的影响。,3.平方取中法,此方法适合于:关键字中的每一位都有某些数字重复出现频度很高的现象。,将关键字分割成若干部分,然后取它们的叠加和为哈希地址。有两种叠加处理的方法:移位叠加和间界叠加。,4.折叠法,此方法适合于:关键字的数字位数特别多。,5.除留余数法,设定哈希函数为:H(key)=keyMODp其中,pm(表长)并且p应为不大于m的素数或是不含20以下的质因子,给定一组关键字为:12,39,18,24,33,21,若取p=9,则他们对应的哈希函数值将为:3,3,0,6,6,3,例如:,为什么要对p加限制?,可见,若p中含质因子3,则所有含质因子3的关键字均映射到“3的倍数”的地址上,从而增加了“冲突”的可能。,6.随机数法,设定哈希函数为:H(key)=Random(key)其中,Random为伪随机函数,通常,此方法用于对长度不等的关键字构造哈希函数。,实际造表时,采用何种构造哈希函数的方法取决于建表的关键字集合的情况(包括关键字的范围和形态),总的原则是使产生冲突的可能性降到尽可能地小。,“处理冲突”的实际含义是:为产生冲突的地址寻找下一个哈希地址,1.开放定址法,2.链地址法,三、处理冲突的方法,为产生冲突的地址H(key)求得一个地址序列:H0,H1,H2,Hs1sm-1其中:H0=H(key)Hi=(H(key)+di)MODmi=1,2,s,1.开放定址法,对增量di有三种取法:,1)线性探测再散列di=ci最简单的情况c=12)平方探测再散列di=12,-12,22,-22,3)随机探测再散列di是一组伪随机数列或者di=iH2(key)(又称双散列函数探测),即:产生的Hi均不相同,且所产生的s(m-1)个Hi值能覆盖哈希表中所有地址。则要求:,注意:增量di应具有“完备性”,随机探测时的m和di没有公因子。,平方探测时的表长m必为形如4j+3的素数(如:7,11,19,23,等);,例如:关键字集合19,01,23,14,55,68,11,82,36,设定哈希函数H(key)=keyMOD11(表长=11),19,01,23,14,55,68,19,01,23,14,68,若采用线性探测再散列处理冲突,若采用二次探测再散列处理冲突,11,82,36,55,11,82,36,112136251,H2(key)是另设定的一个哈希函数,它的函数值应和m互为素数。,若m为素数,则H2(key)可以是1至m-1之间的任意数;,若m为2的幂次,则H2(key)应是1至m-1之间的任意奇数。,例如,当m=11时,可设H2(key)=(3key)MOD10+1,19,01,23,14,55,68,11,82,36,211121213,将所有哈希地址相同的记录都链接在同一链表中。,0123456,14,01,36,19,82,23,11,68,55,ASL=(61+22+3)/9=13/9,例如:同前例的关键字,哈希函数为H(key)=keyMOD7,2.链地址法,查找过程和造表过程一致。假设采用开放定址处理冲突,则查找过程为:,对于给定值K,计算哈希地址i=H(K),若ri=NULL则查找不成功,若ri.key=K则查找成功,否则“求下一地址Hi”,直至rHi=NULL(查找不成功)或rHi.key=K(查找成功)为止。,四、哈希表的查找,inthashsize=997,.;typedefstructElemType*elem;intcount;/当前数据元素个数intsizeindex;/hashs

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论