版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認(rèn)領(lǐng)
文檔簡介
1、棧 隊列 遞歸,第三章棧和隊列,1,棧 ( Stack ),定義:是限定僅在表尾進行插入或刪除操作的線性表。允許插入和刪除的一端稱為棧頂(top),另一端稱為棧底(bottom)特點:后進先出 (LIFO),,a1,,,,,,,top,bottom,,,an....,進棧,出棧,2,棧的抽象數(shù)據(jù)類型定義為: ADT Stack { 數(shù)據(jù)對象:D={ai|ai∈ElemSet, i=1,2,...,
2、n, n≥0 } 數(shù)據(jù)關(guān)系:R1={ | ai-1 , ai ∈D, i=2,...,n } 約定an端為棧頂,a1端為棧底。 基本操作: …….} ADT Stack,棧的抽象數(shù)據(jù)類型 (C語言),template class Stack {public: Stack ( int sz = 10 ); //構(gòu)造函數(shù) void Push ( Type&am
3、p; item); //進棧 Type Pop ( ); //出棧 Type GetTop ( ); //取棧頂元素 void MakeEmpty ( ); //置空棧 int IsEmpty ( ) const; //判??辗?int IsFull ( ) const;
4、 //判棧滿否},棧的抽象數(shù)據(jù)類型 (C++),棧的表示和實現(xiàn),順序棧:棧的順序存儲結(jié)構(gòu),利用一組地址連續(xù)的存儲單元依次存放自棧底到棧頂?shù)臄?shù)據(jù)元素,指針top指向棧頂元素在順序棧中的下一個位置,base為棧底指針,指向棧底的位置。,5,6,順序棧的定義及存儲表示,#define STACK_INIT_SIZE 100//棧存儲空間的初始分配量#define STACKINCREMENT 10// 棧存儲空
5、間的分配增量typedef struct{SElemType *base;//??臻g基址稱為棧底指針,指向棧底位置SElemType *top //棧頂指針,約定棧頂指針指向棧頂元素的 //下(后面)一個位置; int stacksize; //當(dāng)前分配的??臻g大小 //(以sizeof(SElemType)為單位)}SqSta
6、ck;// SqStack::結(jié)構(gòu)類型名,7,初始化操作參數(shù):S是存放棧的結(jié)構(gòu)變量功能:建立一個空棧S,Status InitStack_Sq(SqStack &S) { //構(gòu)造一個空棧S S.base=(SElemType * )malloc(STACK_INIT_SIZE * sizeof(SElemType)); //為順序棧動態(tài)分配存儲空間 if (! S. b
7、ase) exit(OVERFLOW); //存儲分配失敗 S.top=S.base; S.stacksize=STACK_INIT_SIZE; return OK; }//InitStack_Sq,8,取棧頂操作功能:取棧頂元素,并用e返回,Status GetTop_Sq(SqStack S, SelemType &e) { // 若棧不空
8、,則用e返回S的棧頂元素,并返回OK;//否則返回ERROR if (S.top= =S.base) return ERROR; //若棧為空 e = * (S.top-1); return OK;}//GetTop_Sq,9,進棧操作Push功能:元素e進棧,Status Push(SqStack &S, SElemType e) { //將元素e插入棧成為新的
9、棧頂元素,要考慮上溢情況 if (S.top-S.base>=S.stacksize) {//棧滿,追加存儲空間 S.base= (SElemType * )realloc(S.base, (S.stacksize +STACKINCREMENT) sizeof(ElemType)); if (! S. base) exit(OVERFLOW
10、); //存儲分配失敗 S.top=S.base+S.stacksize; S.stacksize+=STACKINCREMENT; } *S.top++=e; //元素e 插入棧頂,修改棧頂指針 return OK; }//Push,10,出棧操作Pop功能:棧頂元素退棧,并用e返回,Status Pop(SqStack &S, SElemTyp
11、e &e) { //若棧不空,則刪除S的棧頂元素,用e 返回其值并返回OK //否則返回ERROR if (S.top= = S.base) return ERROR; //??眨祷谽RROR e = * --S.top; //刪除棧頂元素,用e 返回其值,并修改棧頂指針 return OK;} //Pop,11,#include template c
12、lass Stack {private: int top; //棧頂指針 Type *elements; //棧元素數(shù)組 int maxSize; //棧最大容量public: Stack ( int sz = 10 ); //構(gòu)造函數(shù) ~Stack ( ) { delet
13、e [ ] elements; } void Push ( Type & item ); //進棧,棧的數(shù)組表示 — 順序棧(C++),Type Pop ( ); //出棧 Type GetTop ( ); //取棧頂 void MakeEmpty ( ) { top = -1; } //置空棧 in
14、t IsEmpty ( ) const { return top == -1; } int IsFull ( ) const { return top == maxSize-1; }}template Stack ::Stack ( int s ) : top (-1), maxSize (s) { elements = new Type[maxSize]; assert (
15、elements != NULL ); //斷言},template void Stack ::Push ( Type & item ) { assert ( !IsFull ( ) ); //先決條件斷言 elements[++top] = item; //加入新元素}template int stack ::Pop ( ) { if ( IsEmpty
16、 ( ) ) return 0; //棧空不退棧 top--; return 1; //退出棧頂元素},template Type stack::GetTop ( ) { assert ( !IsEmpty ( ) ); //先決條件斷言 return elements[top]; //取出棧頂元素}雙棧共享一個??臻g,b[0]
17、 t[0] t[1] b[1],,,,,,,,0 maxSize-1,V,,,程序中定義多個棧,(1)定義共享棧數(shù)據(jù)結(jié)構(gòu)#define MAX 100 int stack[MAX],top1=0,top2=MAX
18、-1;,,,,,,,,,,,,,,,,,,,,棧1,,top1,,top2,,棧2,16,(2)共享進棧算法 void push1(int x) {if (top1>top2) printf(“overflow”); else {stack[top1]=x;top1++;}} void push2(int x) {if(top1>top2) printf(“overflow”
19、); else {stack[top2]=x;top2--;},17,(3)共享出棧算法 int pop1(){if top1==0){printf(“underflow”);return(NULL);}top1--;return(stack[top1]);}int pop2(){if(top2==MAX-1){printf(“underflow”);return(NULL):} top2++;return(s
20、tack[top2]);},18,鏈?zhǔn)綏?棧的鏈接表示,鏈?zhǔn)綏o棧滿問題,空間可擴充插入與刪除僅在棧頂處執(zhí)行鏈?zhǔn)綏5臈m斣阪滎^適合于多棧操作,top,,,,,,,,,,,,,,,,,,,19,20,鏈?zhǔn)綏?(LinkedStack)中結(jié)點的定義,鏈?zhǔn)綏?(LinkedStack)結(jié)構(gòu)定義,typedef struct LNode{ ElemType data; struct LNode *next;}*
21、SLink;,typedef struct{ SLink top; //棧頂指針 int length; //棧中元素個數(shù)}LStack;,21,鏈?zhǔn)綏?(LinkedStack)的基本操作,void InitStack ( LStack &S ) { // 構(gòu)造一個空棧 S S.top = NULL; // 設(shè)棧頂指針的初值為空 S.length = 0; // 空棧中
22、元素個數(shù)為0 } // InitStackStatus GetTop(LStack S, SelemType &e) { // 若??談t返回ERROR ,否則返回OK if (S->next= =NULL) return ERROR; //若棧為空 e = * (S->next->data); return OK;}//GetTop,22,鏈?zhǔn)綏?
23、(LinkedStack)的基本操作,void Push ( LStack &S, ElemType e ) { // 在棧頂之上插入元素 e 為新的棧頂元素 p = (LNode *)malloc(sizeof(LNode); // 建新的結(jié)點 if(!p) exit(1); // 存儲分配失敗 p -> data =
24、e; p -> next = S.top; // 鏈接到原來的棧頂 S.top = p; // 移動棧頂指針 ++S.length; // 棧的長度增1 } // Push,23,鏈?zhǔn)綏?(LinkedStack)的基本操作,bool Pop ( LStack &S, ElemType &e ) { // 若棧不空,則刪除S的棧頂元素,用 e 返回其值, // 并返回 TR
25、UE;否則返回 FALSE if ( !S.top ) return FALSE; else { e = S.top -> data; // 返回棧頂元素 q = S.top; S.top = S.top -> next; // 修改棧頂指針 --S.length; // 棧的長度減1 delete q; // 釋放被刪除的結(jié)點空間
26、 return TRUE; } } // Pop,template class Stack;template class StackNode {friend class Stack;private: Type data; //結(jié)點數(shù)據(jù) StackNode *link; //結(jié)點鏈指針public: StackNode ( Typ
27、e d = 0, StackNode *l = NULL ) : data ( d ), link ( l ) { }};,鏈?zhǔn)綏?(LinkedStack)類的定義(C++),template class Stack {private: StackNode *top; //棧頂指針public: Stack ( ) : top ( NULL ) { } ~Stack ( )
28、; void Push ( const Type & item); //進棧 int Pop ( ); //退棧 Type *GetTop ( ); //讀取棧頂元素 void MakeEmpty ( ); //實現(xiàn)與~Stack( )同 int IsEmpty ( ) { return
29、top == NULL; }},template Stack ::~Stack ( ) { StackNode *p; while ( top != NULL ) //逐結(jié)點回收 { p = top; top = top->link; delete p; }}template void Stack ::Push ( const Type &item ) {
30、top = new StackNode ( item, top ); //新結(jié)點鏈入*top之前, 并成為新棧頂},template int Stack ::Pop ( ) { if ( IsEmpty ( ) ) return 0; StackNode *p = top; top = top->link; //修改棧頂指針 delete p; return
31、 1; //釋放}template Type Stack::GetTop ( ) { assert ( !IsEmpty ( ) ); return top->data;},,棧的應(yīng)用舉例,數(shù)制轉(zhuǎn)換行編輯程序迷宮求解表達式求值,28,數(shù)制轉(zhuǎn)換十進制數(shù)轉(zhuǎn)換為八進制數(shù)。采用對十進制數(shù)除8取余的方法,可得到八進制數(shù)的倒序。 N = (N div d)×d + N mod
32、 d 例如:(1348)10 = (2504)8 ,其運算過程如下:N N div 8 N mod 81348 168 4 168 21 0 21 2 5 2 0 2,29,void conversion () { InitStack(S); scan
33、f ("%d",N); while (N) { Push(S, N % 8); N = N/8; } while (!StackEmpty(S)) { Pop(S,e); printf ( "%d", e ); }} // conversion,30,行編輯程序在用戶輸入一行的過程中,允許 用戶輸入出差錯,并在
34、發(fā)現(xiàn)有誤時可以及時更正。設(shè)立一個輸入緩沖區(qū),用以接受用戶輸入的一行字符,然后逐行存入用戶數(shù)據(jù)區(qū); 并假設(shè)“#”為退格符,“@”為退行符。假設(shè)從終端接受兩行字符: whli##ilr#e(s#*s) outcha@putchar(*s=#++);實際有效行為: while (*s) putchar(*s++);,31,Void LineEdit(){InitStac
35、k(s);ch=getchar();while (ch != EOF) { //EOF為全文結(jié)束符while (ch != EOF && ch != '\n') { switch (ch) {case '#' : Pop(S, ch); break; case '@': ClearStack(S); break;
36、// 重置S為空棧 default : Push(S, ch); break; } ch = getchar(); // 從終端接收下一個字符 }//while,32,將從棧底到棧頂?shù)淖址麄魉椭琳{(diào)用過程的數(shù)據(jù)區(qū);ClearStack(S); // 重置S為空棧if (ch != EOF) ch = getchar();} //while
37、DestroyStack(s);},33,迷宮求解通常用的是“窮舉求解”的方法,34,迷宮路徑算法的基本思想,若當(dāng)前位置“可通”,則納入路徑,繼續(xù)前進;若當(dāng)前位置“不可通”,則后退,換方向繼續(xù)探索;若四周“均無通路”,則將當(dāng)前位置從路徑中刪除出去。,,,35,設(shè)定當(dāng)前位置的初值為入口位置; do{ 若當(dāng)前位置可通, 則{將當(dāng)前位置插入棧頂; 若該位置是出口位置,則算法結(jié)束;
38、 否則切換當(dāng)前位置的東鄰方塊為新的 當(dāng)前位置; }………..,36,否則 {若棧不空且棧頂位置尚有其他方向未被探索,則設(shè)定新的當(dāng)前位置為: 沿順時針方向旋轉(zhuǎn) 找到的棧頂位置的下一相鄰塊;若棧不空但棧頂位置的四周均不可通,則{刪去棧頂位置;// 從路徑中刪去該通道塊 若棧不空,則重新測試新的棧頂位置, 直至找到一個可通的相鄰塊或出棧至棧空
39、;}}}while (棧不空);,37,typedef struct {intord;//序號PosTypeseat;//坐標(biāo)intdi;//方向}SElemType;//棧元素Status MazePath (MazeType maze, PosType start, PosType end) {InitStack(S); curpos=start;//當(dāng)前位置curstep=1;
40、,38,do {if (Pass(curpos)) {//可通過且未走過FootPrint(curpos);//記已通過標(biāo)記e=(curstep, curpos, 1);Push (S, e);if (curpos == end) return (TRUE);curpos = NextPos ( curpos, 1);curstep++;}//if,39,else {if
41、 (!StackEmpty(S)) {Pop(S, e);while (e.di==4 && !StackEmpty(S)) {MarkPrint(e.seat); Pop(S,e);//記不能通過標(biāo)記}//whileif(e.di<4) {e.di++; Push(S, e);curpos = NextPos(e.seat, e.di);
42、}//if}//if}//else}while (!StackEmpty(S));return (FALSE);}//MazePath,40,限于二元運算符的表達式定義: 表達式 ::= (操作數(shù)) + (運算符) + (操作數(shù)) 操作數(shù) ::= 簡單變量 | 表達式 簡單變量 :: = 標(biāo)識符 | 無符號整數(shù)Exp = S1 + OP + S2前綴表示法OP + S1 + S2中綴表示
43、法 S1 + OP + S2后綴表示法 S1 + S2 + OP,表達式求值,41,例如: Exp = a ? b + (c ? d / e) ? f前綴式: + ? a b ? ? c / d e f中綴式: a ? b + c ? d / e ? f后綴式: a b ? c d e / ? f ? +,表達式標(biāo)識方法,42,表達式的中綴表示,a + b * (
44、 c - d ) - e ^ f / g表達式中相鄰兩個操作符的計算次序為:優(yōu)先級高的先計算;優(yōu)先級相同的自左向右計算;當(dāng)使用括號時從最內(nèi)層括號開始計算。,,rst1,,rst2,,rst3,,rst4,,rst5,,rst6,C++中操作符的優(yōu)先級,優(yōu)先級 操作符 1 單目-、! 2 *、/、% 3 +、-
45、 4 、>= 5 ==、!= 6 && 7 ||,一般表達式的操作符有4種類型: 算術(shù)操作符 如雙目操作符(+、-、*、/ 和%)以及單目操作符(-)。 關(guān)系操作符 包括=、>。這些操作符主要用于比較。 邏輯操作符 如與(&&)、
46、或(||)、非(!)。 括號‘(’和‘)’ 它們的作用是改變運算順序。,后綴表示法計算表達式的值,從左向右順序地掃描表達式,并用一個棧暫存掃描到的操作數(shù)或計算結(jié)果。在后綴表達式的計算順序中已隱含了加括號的優(yōu)先次序,括號在后綴表達式中不出現(xiàn)。計算例 a b c d - * + e f ^ g / -,,rst1,,rst2,,rst3,,rst4,,rst5,,rst6,通過后綴表示計算表達式值的過程,順序掃描表達式的每一項,
47、根據(jù)它的類型做如下相應(yīng)操作:若該項是操作數(shù),則將其壓棧;若該項是操作符,則連續(xù)從棧中退出兩個操作數(shù)Y和X,形成運算指令XY,并將計算結(jié)果重新壓棧。當(dāng)表達式的所有項都掃描并處理完后,棧頂存放的就是最后的計算結(jié)果。,void Calculator :: Run ( ) { char ch; double newoperand; while ( cin >> ch, ch != ‘=’ ) {
48、 switch ( ch ) { case ‘+’ : case ‘-’ : case ‘*’ : case ‘/’ : DoOperator ( ch ); break; //計算 default : cin.putback ( ch ); //將字符放回輸入流 ci
49、n >> newoperand; //讀操作數(shù) AddOperand ( newoperand ); } }},利用棧將中綴表示轉(zhuǎn)換為后綴表示,使用??蓪⒈磉_式的中綴表示轉(zhuǎn)換成它的前綴表示和后綴表示。為了實現(xiàn)這種轉(zhuǎn)換,需要考慮各操作符的優(yōu)先級。,算符間優(yōu)先級,,c2棧外,c1棧內(nèi),52,各個算術(shù)操作符的優(yōu)先級,isp叫做棧內(nèi)(in stack prior
50、ity)優(yōu)先數(shù)icp叫做棧外(in coming priority)優(yōu)先數(shù)。操作符優(yōu)先數(shù)相等的情況只出現(xiàn)在括號配對或棧底的“#”號與輸入流最后的“#”號配對時。,從中綴式求得后綴式方法,設(shè)立暫存運算符的棧;設(shè)表達式的結(jié)束符為“#”, 予設(shè)運算符棧的棧底為“#”若當(dāng)前字符是操作數(shù),則直接發(fā)送給后綴式;(后綴與前綴式操作數(shù)的順序是相同的)若當(dāng)前運算符的優(yōu)先數(shù)高于棧頂運算符,則進棧;否則,退出棧頂運算符發(fā)送給后綴式;“(” 對它
51、之前后的運算符起隔離作用,“)”為自左括弧開始的表達式的結(jié)束符。,54,void postfix ( expression e ) { stack s; char ch, op; s.Push ( ‘#’ ); cin.Get ( ch ); while ( ! s.IsEmpty( ) && ch != ‘#' ) if ( isdigit ( ch ) )
52、 { cout icp ( ch ) ) { op = s.GetTop ( ); s.Pop( ); cout << op; } else { op = s.GetTop ( ); s.Pop( ); if ( op == ‘(’ ) cin.Get ( ch ); } }
53、},為實現(xiàn)算符優(yōu)先算法,在這里用了兩個工作棧。一個存放算符OPTR,另一個存放數(shù)據(jù)OPND。算法思想是:(1)首先置數(shù)據(jù)棧為空棧,表達式起始符“?!睘樗惴麠5臈5自兀?)自左向右掃描表達式,讀到操作數(shù)進OPND棧,讀到運算符,則和OPTR棧頂元素比較(棧頂元素為c1,讀到的算符為c2);若c1c2,則將c1出棧,并在操作數(shù)棧取出兩個元素a和b按c1做運算,運算結(jié)果進OPND.重復(fù)直到表達式求值完畢。,56,中綴算術(shù)表達式求值
54、,例如:表達式3*(7-2),求值過程如下表:,57,為使兩個算符比較方便,給算符設(shè)置優(yōu)先級,如下表,其中c1為棧內(nèi)元素,c2為棧外元素,58,算符比較算法,char Precede(char c1,char c2){int c_temp1,c_temp2; switch(c1){ case ‘*’: case ‘/’:c_temp1=4;break;case ‘+’: case ‘-’:c_temp1=2;b
55、reak; case ‘(’:c_temp1=0;break; case ‘)’:c_temp1=5;break; case ‘#’:c_temp1=-1;},59,switch(c2){ case ‘*’: case ‘/’:c_temp2=3;break; case ‘+’: case ‘-’:c_temp2=1;break; case ‘(’:c_temp2=5;break;
56、 case ‘)’:c_temp2=0;break; case ‘#’:c_temp2=-1;}if(c_temp1c_temp2) return(‘>‘);},switch(c1){ case ‘*’: case ‘/’:c_temp1=4;break;case ‘+’: case ‘-’:c_temp1=2;break; case ‘(’:c_temp1=0;break; case
57、‘)’:c_temp1=5;break; case ‘#’:c_temp1=-1;},60,OperandType EvaluateExpression() {InitStack (OPTR); Push ( OPTR,’#’);InitStack (OPND); c=getchar();while (c!=‘#’|| GetTop(OPTR)!=‘#’) {if(!In(c,OP)){Push(OPND,c);
58、c=getchar();}elseswitch(Precede(GetTop(OPTR),c){case ‘<‘://棧頂元素優(yōu)先權(quán)低Push(OPTR,c); c=getchar();break;,算符優(yōu)先算法求表達式值,61,case ‘=‘://脫括號Pop(OPTR,x); c=getchar();break;case ‘>’://退棧并計算
59、Pop(OPTR,theta);Pop(OPND,b); Pop(OPND,a);Push(OPND, Operate(a,theta,b));break;}//switch}//whilereturn GetTop(OPND);}//EvaluateExpression,62,隊列,定義:只允許在表的一端進行插入,而在另一端刪除元素的線性表。在隊列中,允許插入的一端叫隊尾(r
60、ear),允許刪除的一端稱為對頭(front)。特點:先進先出 (FIFO),a1 ,a2, a3,…,an,,,出隊列,入隊列,,,隊頭,隊尾,63,鏈隊列:隊列的鏈?zhǔn)奖硎?鏈隊列中,有兩個分別指示隊頭和隊尾的指針。鏈?zhǔn)疥犃性谶M隊時無隊滿問題,但有隊空問題。,64,空隊列,65,typedef struct QNode{ //鏈隊列結(jié)點的類型定義 QElemType data; //用于存放隊列元素 st
61、ruct QNode *next; //用于存放元素直接后繼 //結(jié)點的地址}QNode,*QueuePtr;typedef struct{ //鏈隊列的表頭結(jié)點的的類型定義QueuePtr front; //隊頭指針,指向鏈表的頭結(jié)點QueuePtr rear; //隊尾指針,指向隊尾結(jié)點}LinkQueue;,鏈?zhǔn)疥犃械谋硎炯盎静僮?/p>
62、(C語言),Status InitQueue_L(LinkQueue &Q) {//建一個空隊列Q.front=Q.rear=(QueuePtr)malloc(sizeof(QNode)); //為鏈隊列的頭結(jié)點分配空間 if (!Q.front) exit(OVERFLOW); Q.front->next=NULL; return OK;} //InitQueue_LSta
63、tus DestroyQueue_L(LinkQueue &Q) {//銷毀隊列Q while(Q.front) { Q.rear = Q.front->next; free(Q.front); Q.front = Q.rear; } return OK;} //DestroyQueue_L,鏈?zhǔn)疥犃械谋硎炯盎静僮?C語言
64、),Status DestroyQueue_L(LinkQueue &Q) { //銷毀隊列Q if (!Q.front) return ERROR; // 鏈隊列不存在 while(Q.front->next) { // 回收鏈隊列的所有元素結(jié)點空間 p=Q.front->next;
65、 Q.front->next=p->next; free(p); } free(Q.front ); // 回收鏈隊列頭結(jié)點空間 Q.front=Q.rear=null; return OK;}//DestroyQueue_L,鏈?zhǔn)疥犃械谋硎炯盎静僮?C語言),S
66、tatus EnQueue_L(LinkQueue &Q, QElemType ) { //在鏈隊列Q隊尾,插入新的隊尾結(jié)點 p=(QueuePtr)malloc(sizeof(QNode)); //為新元素e分配結(jié)點空間 if (!p) exit (OVERFLOW); //存儲分配失敗 p->date=e; p->next=NULL; Q.rear-
67、>next=p; //修改隊尾指針,插入新隊尾結(jié)點 Q.rear=p; return OK; },鏈?zhǔn)疥犃械谋硎炯盎静僮?C語言),Status DeQueue_L(LinkQueue &Q, QElemType &e) { //若隊列不空,則刪除Q的隊頭元素結(jié)點,用e返回其值,并返回OK;否則返回ERROR if (
68、Q.front = =Q.rear) return ERROR; //若隊列空,返回ERROR p=Q.front->next; // p指向隊頭元素結(jié)點 e=p->data; Q.front->next=p->next; // 修改鏈隊列頭結(jié)點指針 if(Q.rear= =p) Q.rear=
69、Q.front; // 對于鏈隊列只有一個元素結(jié)點的情況,要同時修改隊尾指針 free(p); return OK;},鏈?zhǔn)疥犃械谋硎炯盎静僮?C語言),template class Queue;template class QueueNode {friend class Queue;private: Type data; //隊列結(jié)點數(shù)據(jù)
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
評論
0/150
提交評論