大數據結構 二叉樹遍歷實驗資料報告材料
《大數據結構 二叉樹遍歷實驗資料報告材料》由會員分享,可在線閱讀,更多相關《大數據結構 二叉樹遍歷實驗資料報告材料(20頁珍藏版)》請在裝配圖網上搜索。
1、word 數據結構之二叉樹 實 驗 報 告 題目:二叉樹的遍歷和子樹交換 指導教師:政宇 班級:通信1202 :徐江 學號:0909121127 需求分析 1. 演示程序分別用多種遍歷算法遍歷二叉樹并把數據輸出。 2. 輸入字符序列,遞歸方式建立二叉樹。 3.在演示過程序中,用戶敲擊鍵盤,輸入數據,即可看到數據的輸出。 4.實現(xiàn)鏈式存儲的二叉樹的多種遍歷算法。 遍歷算法包括: a) 中序遞歸遍歷算法、前序遞歸遍歷算法【選
2、】 b) 中序遍歷非遞歸算法 c) 先序或后序遍歷非遞歸算法 d) 建立中序線索,并進展中序遍歷和反中序遍歷 6.設計一個測試用的二叉樹并創(chuàng)建對應的存二叉樹,能夠測試自己算法的邊界(包括樹節(jié)點數為0、1以與>1 的不同情形)。 7.測試數據:輸入數據:-+a *b -c d -e f 概要設計 說明:本程序在遞歸調用中用到了鏈表,在非遞歸調用時用到了棧。 1. 棧的抽象數據類型 ADT Stack{ 數據對象:D={ai|ai∈char,i=1,2,3……..} 數據關系:R={< ai-1,ai >| ai-1,ai∈D,i=2,3…..} 根本操作:
3、 InitStack〔&S〕 操作結果:構造一個空棧 StackEmpty( S )初始條件:棧S已存在。操作結果:假設S為空棧,如此返回OK,否如此返回ERROR。 Push( &S, e )初始條件:棧S已存在。操作結果:插入元素e為新的棧頂元素。Pop( &S, &e )初始條件:棧S已存在且非空。操作結果:刪除S的棧頂元素,并用e返回其值。 GetTop( S, &e )初始條件:棧S已存在且非空。操作結果:用e返回S的棧頂元素。 } ADT BinaryTree{ 數據對象D:D是具有一樣特性的數據元素的集合。 數據關系R: 假設D=
4、Φ,如此R=Φ,稱BinaryTree為空二叉樹;
假設D≠Φ,如此R={H},H是如下二元關系;
〔1〕在D中存在惟一的稱為根的數據元素root,它在關系H下無前驅;
〔2〕假設D-{root}≠Φ,如此存在D-{root}={D1,Dr},且D1∩Dr =Φ;
〔3〕假設D1≠Φ,如此D1中存在惟一的元素x1,
5、 〔4〕(D1,{H1})是一棵符合本定義的二叉樹,稱為根的左子樹;(Dr,{Hr})是一棵符合本定義的二叉樹,稱為根的右子樹。 根本操作: CreateBiTree( &T) 初始條件:給出二叉樹T的定義。 操作結果:按要求構造二叉樹T。 PreOrderTraverse_re( T, print() ) 初始條件:二叉樹T存在,print是二叉樹全部結點輸出的應用函數。 操作結果:先序遞歸遍歷T,對每個結點調用函數print一次且僅一次。一旦 print()失敗,如此操作失敗。 InOrderTraverse( T,
6、 print() ) 初始條件:二叉樹T存在,print是二叉樹全部結點輸出的應用函數。 操作結果:中序非遞歸遍歷T,對每個結點調用函數print一次且僅一次。一旦printf()失敗,如此操作失敗。 InOrderTraverse_re(T,print() ) 初始條件:二叉樹T在在,print是二叉樹全部結點輸出的應用函數。 操作結果:中序遞歸遍歷T,對每個結點調用函數print一次且僅一次。一旦 printf()失敗,如此操作失敗。 PreOrderTraverse(T,print()) 初始條件:二叉樹T存在,print是二叉樹全部結
7、點輸出的應用函數。 操作結果:先序非遞歸遍歷T,對每個結點調用函數print一次且僅一次。一旦print()失敗,如此操作失敗。 Levelorder(T) 初始條件:二叉樹T在在。 操作結果:分層遍歷二叉樹T,并輸出。 InOrderThreading(Thrt,T); 初始條件:二叉樹T在在。 操作結果:中序遍歷二叉樹,并將其中序線索化。 InOrderTraverse_Thr( T, print); 初始條件:二叉樹T在在。 操作結果:中序非遞歸遍歷二叉線索樹T InThreading(p); 初始條件:結點p在在。 操作結果:結點p與子樹線
8、索化。 3.主程序的流程: void main() { 初始化; 提示; 執(zhí)行二叉數ADT函數; } 4.本程序包含三個模塊 1) 主程序模塊 void main(){ 初始化; { 承受命令; 顯示結果; } } 2) 鏈表模塊。遞歸調用時實現(xiàn)鏈表抽象數據類型。 3) 棧模塊。非遞歸調用時實現(xiàn)棧的抽象數據類型。 詳細設計 1.宏定義與全局變量 #define TElemType char #define SElemType BiTree #define OK 1 #define OVERFLOW 0 #define ERROR 0
9、 #define STACK_INIT_SIZE 100 #define STACKINCREMENT 10 SqStack S; BiThrTree pre; BiThrTree i; int CreateBiTree(BiTree &T); //創(chuàng)建二叉樹 void PreOrderTraverse_re(BiTree T,void (*print)(TElemType e)); //先序遞歸遍歷二叉樹 void InOrderTraverse(BiTree T,int (*print)(TElemType e)); //中序非遞歸遍歷二叉樹 void
10、 InOrderTraverse_re(BiTree T,int (*print)(TElemType e)) ; //中序遞歸遍歷二叉樹 void PreOrderTraverse(BiTree T,int (*print)(TElemType e)); //先序非遞歸遍歷二叉樹 int print(TElemType e); //打印元素 void InitStack(SqStack &S); //棧的初始化 void Pop(SqStack &S,SElemType &e); void Push(SqStack &S,SElemType &e); int Stack
11、Empty(SqStack S); int GetTop(SqStack S,SElemType &e); void Levelorder(BiTree T) ; void InOrderThreading(BiThrTree &Thrt,BiThrTree T); int InOrderTraverse_Thr(BiThrTree T, int (*print)(TElemType e)); void InThreading(BiThrTree p); 數據結構: typedef struct BiTNode{ TElemType data; struct BiTN
12、ode *lchild ,*rchild; PointerTag LTag , RTag; }BiTNode , *BiTree , BiThrNode , *BiThrTree; 根本操作: a)構造二叉樹T int CreateBiTree(BiTree &T) { char ch; scanf("%c",&ch); if(ch==' ') T=NULL; else { if(!(T=(BiTNode *)malloc(sizeof(BiTNode)))) return ERROR; T->data=ch; if (Cr
13、eateBiTree(T->lchild)) T->LTag=Link; if (CreateBiTree(T->rchild)) T->RTag=Link; } return OK; } b)先序遞歸遍歷二叉數T,并輸出全部結點值。 void PreOrderTraverse_re(BiTree T,int (*print)(TElemType e)) { if(T) { if(print(T->data)) PreOrderTraverse_re(T->lchild,print); PreOrderTraverse_re(T->rchi
14、ld,print); return ; } else return ; } c)中序非遞歸遍歷二叉樹T,并輸出全部結點值 void InOrderTraverse(BiTree T,int (*print)(TElemType e)) { SqStack S; S.base=NULL;S.top=NULL; SElemType p=NULL; InitStack(S); Push(S,T); while(!StackEmpty(S)) { while(GetTop(S,p)&&p) Push(S,p->lchild);
15、 Pop(S,p); if(!StackEmpty(S)) { Pop(S,p); print(p->data); Push(S,p->rchild); } } return; } d)中序遞歸遍歷二叉樹T,并輸出全部結點值 void InOrderTraverse_re(BiTree T,int (*print)(TElemType e)) { if(T) { InOrderTraverse_re(T->lchild,print); print(
16、T->data); InOrderTraverse_re(T->rchild,print); } } e)中序遍歷二叉樹T,并將其中序線索化,Thrt指向頭結點 void InOrderThreading(BiThrTree &Thrt,BiThrTree T) { Thrt=(BiThrTree)malloc(sizeof(BiThrNode)); Thrt->LTag=Link;//建頭結點 Thrt->RTag=Thread; Thrt->rchild=Thrt;//右指針回指 if(!T) Thr
17、t->lchild=Thrt; else { Thrt->lchild=T; pre=Thrt; InThreading(T);//中序遍歷進展中序線索化 pre->rchild=Thrt; pre->RTag=Thread;//最后一個結點線索化 Thrt->rchild=pre; } i=Thrt; }//InOrderThreading f)結點p線索化 void InThreading(BiThrTree p) { if (p) { InThreading(p->lchild); // 左子樹線索化
18、 if (!p->lchild) // 建前驅線索 { p->LTag = Thread; p->lchild = pre; } if (!pre->rchild) // 建后繼線索 { pre->RTag = Thread; pre->rchild = p; } pre = p; // 保持pre指向p的前驅 InThreading(p->rchild); // 右子樹線索化 } } // InThreading g)//中序遍歷線索化二叉樹
19、 int InOrderTraverse_Thr(BiThrTree T, int (*print)(TElemType e)) { BiThrTree p=NULL; p=T->lchild; while(p!=T) { while(p->LTag==Link) p=p->lchild; if(!print(p->data)) return ERROR; while(p->RTag==Thread && p->rchild!=T) { p=p->rchild; print(p->data); } p=p-
20、>rchild; } return OK; } 數據結構: typedef struct{ SElemType *base; SElemType *top; int stacksize; }SqStack; 根本操作: a)創(chuàng)建一個空棧 void InitStack(SqStack &S) { S.base=(SElemType*)malloc(STACK_INIT_SIZE*sizeof(SElemType)); S.top=S.base; //初始為空 S.stacksize=STACK_INIT_SIZE; return;
21、 } b)棧頂插入元素 void Push(SqStack &S,SElemType &e) { if(S.top-S.base>=S.stacksize) { S.base=(SElemType*)realloc(S.base,(STACK_INIT_SIZE+STACKINCREMENT)*sizeof(SElemType)); S.top=S.base+S.stacksize; S.stacksize+=STACKINCREMENT; } *S.top++=e; } c)棧頂刪除元素 void Pop(SqStack &S,SElemTy
22、pe &e) { if(S.top==S.base) return; e=*--S.top; return; } d)判斷棧是否為空棧 int StackEmpty(SqStack S) { if(S.top==S.base) return OK; else return ERROR; } e)e返回S的棧頂元素 int GetTop(SqStack S,SElemType &e) { if(S.top==S.base) return ERROR; e=*(S.top-1); return OK; } vo
23、id main() {int flag; BiTree T; BiThrTree Thrt; printf("******************************************************\n"); printf("** 實驗12 二叉樹的遍歷 **\n"); printf("** 1. 實現(xiàn)二叉樹的不同遍歷算法和二叉樹的中序線索化算法 **\n"); printf("** a) 中序遞歸遍歷算法; **\n"
24、); printf("** b) 先序遞歸遍歷算法; **\n"); printf("** c) 中序遍歷的非遞歸算法; **\n"); printf("** d) 先序或后序遍歷非遞歸算法之一; **\n"); printf("** e) 建立中序線利用線索進展中序遍歷和反中序遍歷。 **\n"); printf("** 2. 實現(xiàn)二叉樹的按層遍歷算法。 **\n"
25、); printf("**********************************************************\n"); printf("\n選擇操作:\n\t1.先序與中序遍歷算法\n\t2.中序線索的中序遍歷和反中序遍歷算法\n\t3.按層遍歷算法\n請選擇:"); scanf("%d",&flag); switch(flag) { case 1: printf("前序遞歸創(chuàng)建二叉樹〔空格 表示此結點為空〕:\n"); getchar(); CreateBiTree(T); printf("中序
26、遞歸遍歷輸出:"); InOrderTraverse_re(T,print); printf("\n前序遞歸遍歷輸出:"); PreOrderTraverse_re(T,print); printf("\n中序非遞歸遍歷輸出:"); InOrderTraverse(T,print); printf("\n前序非遞歸遍歷輸出:"); PreOrderTraverse(T,print); printf("\n"); break; case 2: printf("前序遞歸創(chuàng)建二叉樹〔空格 表示此結點為
27、空〕:\n"); getchar(); CreateBiTree(T); printf("\n中序遍歷線索化二叉樹:"); InOrderThreading(Thrt , T); InOrderTraverse_Thr(Thrt , print); break; case 3: printf("前序遞歸創(chuàng)建二叉樹〔空格 表示此結點為空〕:\n"); getchar(); CreateBiTree(T); printf("\n按層遍歷輸出:"); Levelorder(T);
28、printf("\n"); break; default:return; }} 6. 函數間調用關系 main InOrderTraverse_re CreateBitree PreOrderTraverse_re InOrderTraverse PreOrderTraverse InOrderThreading InOrderTraverse_Thr Threading Stack操作 調試分析 1、二叉樹的分層遍歷,開始時想用隊列來做,但考慮到比擬麻煩,因而改為數組模擬隊列,簡單易懂,課后
29、可自行嘗試用隊列來做。 2.? 在線索化二叉樹時考慮到如果將兩種存儲結構分開將導致兩個類型的指針不能互相傳值,造成許多麻煩。比擬兩種存儲結構發(fā)現(xiàn),線索二叉樹比二叉樹多了兩個標志域LTag,Rtag。于是把兩種存儲結構合并為BiThrNode,并在建立二叉樹時把LTag,Rtag均置為Link。程序正常運行。 3.進入演示程序,完成編譯,連接〔即按下Ctrl F5〕進入演示界面,或直接打開執(zhí)行文件BiTree.exe,產生如如如下圖所示的界面: ⒈ 用戶需根據用戶提示信息操作,輸入二叉樹〔以空格表示空結點〕,輸入完成后按回車鍵,屏幕上打印出對應于該二叉樹的各種遍歷結果。如如如
30、下圖:
六、 測試結果
輸入:-+a *b -c d -e f
屏幕輸出:
中序遞歸遍歷輸出:a+b*c-d
前序遞歸遍歷輸出:+a*b-cd
中序非遞歸遍歷輸出:a+b*c-d
前序非遞歸遍歷輸出:+a*b-cd
按層遍歷輸出:+a*b-cd
中序遍歷線索化二叉樹:a+b*c-d
七、 附錄
#include
31、efine ERROR 0 #define STACK_INIT_SIZE 100 #define STACKINCREMENT 10 typedef enum PointerTag{Link,Thread}; //Link==0,指針,Thread==1,線索 typedef struct BiTNode{ TElemType data; struct BiTNode *lchild ,*rchild; PointerTag LTag , RTag; }BiTNode , *BiTree , BiThrNode , *BiThrTree; //二叉樹
32、 #define QElemType BiTNode #define SElemType BiTree typedef struct{ SElemType *base; SElemType *top; int stacksize; }SqStack; //全局變量 SqStack S; BiThrTree pre; BiThrTree i; /*函數聲明*/ int CreateBiTree(BiTree &T); //創(chuàng)建二叉樹 void PreOrderTraverse_
33、re(BiTree T,void (*print)(TElemType e)); //先序遞歸遍歷二叉樹 void InOrderTraverse(BiTree T,int (*print)(TElemType e)); //中序非遞歸遍歷二叉樹 void InOrderTraverse_re(BiTree T,int (*print)(TElemType e)) ; //中序遞歸遍歷二叉樹 void PreOrderTraverse(BiTree T,int (*print)(TElemType e)); //先序非遞歸遍歷二叉樹 int print(TElemType e);
34、 //打印元素 void InitStack(SqStack &S); //棧的初始化 void Pop(SqStack &S,SElemType &e); void Push(SqStack &S,SElemType &e); int StackEmpty(SqStack S); int GetTop(SqStack S,SElemType &e); void Levelorder(BiTree T) ; void InOrderThreading(BiThrTree &Thrt,BiThrTree T); int InOrderTraverse_Thr(BiThrTr
35、ee T, int (*print)(TElemType e)); void InThreading(BiThrTree p); /*二叉樹的創(chuàng)建遞歸創(chuàng)建*/ int CreateBiTree(BiTree &T) { char ch; scanf("%c",&ch); if(ch==' ') T=NULL; else { if(!(T=(BiTNode *)malloc(sizeof(BiTNode)))) return ERROR; T->data=ch; if (CreateBiTree(T->lchild)) T-
36、>LTag=Link; if (CreateBiTree(T->rchild)) T->RTag=Link; } return OK; } /*******************************************/ /* 先序遞歸遍歷輸出 */ /*******************************************/ void PreOrderTraverse_re(BiTree T,int (*print)(TElemType e)) { if(T) { if
37、(print(T->data)) PreOrderTraverse_re(T->lchild,print); PreOrderTraverse_re(T->rchild,print); return ; } else return ; } /*******************************************/ /* 中序非遞歸遍歷輸出 */ /*******************************************/ void InOrderTraver
38、se(BiTree T,int (*print)(TElemType e)) { SqStack S; S.base=NULL;S.top=NULL; SElemType p=NULL; InitStack(S); Push(S,T); while(!StackEmpty(S)) { while(GetTop(S,p)&&p) Push(S,p->lchild); Pop(S,p); if(!StackEmpty(S)) { Pop(S,p); print(p->data); Push(S,p->rchild
39、); } } return; } /*******************************************/ /* 中序遞歸遍歷輸出 */ /*******************************************/ void InOrderTraverse_re(BiTree T,int (*print)(TElemType e)) { if(T) { InOrderTraverse_re(T->lchild,p
40、rint); print(T->data); InOrderTraverse_re(T->rchild,print); } return ; } /*******************************************/ /* 按照前序非遞歸遍歷二叉樹:棧 */ /*******************************************/ void PreOrderTraverse(BiTree T,int (*print)(
41、TElemType e)) { SqStack S; S.base=NULL;S.top=NULL; SElemType p=T;//p指向當前訪問的結點 InitStack(S); while(p||!StackEmpty(S)) { if(p) { print(p->data); Push(S,p); p=p->lchild; }
42、else { Pop(S,p); p=p->rchild; } } return; } void InOrderThreading(BiThrTree &Thrt,BiThrTree T) //中序遍歷二叉樹T,并將其中序線索化,Thrt指向頭結點 { Thrt=(BiThrTree)malloc(sizeof(BiThrNode)); Thrt->LTag=Link;//建頭結點 Thrt->RTag=Thread;
43、 Thrt->rchild=Thrt;//右指針回指 if(!T) Thrt->lchild=Thrt; else { Thrt->lchild=T; pre=Thrt; InThreading(T);//中序遍歷進展中序線索化 pre->rchild=Thrt; pre->RTag=Thread;//最后一個結點線索化 Thrt->rchild=pre; } i=Thrt; }//InOrderThreading void InThreading(BiThrTree p) { if (p) { I
44、nThreading(p->lchild); // 左子樹線索化 if (!p->lchild) // 建前驅線索 { p->LTag = Thread; p->lchild = pre; } if (!pre->rchild) // 建后繼線索 { pre->RTag = Thread; pre->rchild = p; } pre = p; // 保持pre指向p的前驅 InThreading(p->rchild); // 右子樹線索化 } } // InT
45、hreading int InOrderTraverse_Thr(BiThrTree T, int (*print)(TElemType e)) //中序遍歷線索化后的二叉樹 { BiThrTree p=NULL; p=T->lchild; while(p!=T) { while(p->LTag==Link) p=p->lchild; if(!print(p->data)) return ERROR; while(p->RTag==Thread && p->rchild!=T) { p=p->rchild;
46、print(p->data); } p=p->rchild; } return OK; } /***************************以下為輔助函數***************************************/ int print(TElemType e) { printf("%c",e); return OK; } /*棧函數*/ /*棧的初始化*/ void InitStack(SqStack &S) { S.base=(SElemType*)malloc(STACK_INIT_SIZE*sizeof(S
47、ElemType)); S.top=S.base; //初始為空 S.stacksize=STACK_INIT_SIZE; return; } /*棧頂插入元素*/ void Push(SqStack &S,SElemType &e) { if(S.top-S.base>=S.stacksize) { S.base=(SElemType*)realloc(S.base,(STACK_INIT_SIZE+STACKINCREMENT)*sizeof(SElemType)); S.top=S.base+S.stacksize; S.stacksize
48、+=STACKINCREMENT; } *S.top++=e; } /*棧頂刪除元素*/ void Pop(SqStack &S,SElemType &e) { if(S.top==S.base) return; e=*--S.top; return; } int StackEmpty(SqStack S) /*假設棧為空棧,如此返回OK,否如此返回ERROR*/ { if(S.top==S.base) return OK; else return ERROR; } int GetTop(SqStack S,SElem
49、Type &e) { if(S.top==S.base) return ERROR; e=*(S.top-1); return OK; } /************************************************************/ /* 按層次順序建立一棵二叉樹 */ /************************************************************/ void Levelorder(BiTree T) {
50、 int i,j; BiTNode *q[20],*p; /*q[20]用于模擬隊列,存儲入隊的結點*/ p=T; if(p!=NULL) { i=1;q[i]=p;j=2; } /*i為隊首位置,j為隊尾位置*/ while(i!=j) { p=q[i]; printf("%c",p->data); /*訪問隊首元素*/ if (p->lchild!=NULL) { q[j]=p->lch
51、ild; j++; } /*假設隊首元素左鏈域不為空,如此將其入隊列*/ if (p->rchild!=NULL) { q[j]=p->rchild; j++; } /*假設隊首元素右鏈域不為空,如此將其入隊列*/ i++; /*將隊首移到下一個位置*/ } } void main() { int flag; BiTree T; BiThrT
52、ree Thrt; printf("**********************************************************\n"); printf("** 實驗12 二叉樹的遍歷 **\n"); printf("** 1. 實現(xiàn)二叉樹的不同遍歷算法和二叉樹的中序線索化算法 **\n"); printf("** a) 中序遞歸遍歷算法; **\n"); printf("** b) 先序遞歸遍歷算法;
53、 **\n"); printf("** c) 中序遍歷的非遞歸算法; **\n"); printf("** d) 先序或后序遍歷非遞歸算法之一; **\n"); printf("** e) 建立中序線利用線索進展中序遍歷和反中序遍歷。 **\n"); printf("** 2. 實現(xiàn)二叉樹的按層遍歷算法。 **\n"); printf("*************************
54、*********************************\n"); /* printf("\n選擇操作:\n\t1.先序與中序遍歷算法\n\t2.中序線索的中序遍歷和反中序遍歷算法\n\t3.按層遍歷算法\n請選擇:"); scanf("%d",&flag); switch(flag) { case 1: printf("前序遞歸創(chuàng)建二叉樹〔空格 表示此結點為空〕:\n"); getchar(); CreateBiTree(T); printf("中序遞歸遍歷輸出:"); InOrderTraverse_re(
55、T,print); printf("\n前序遞歸遍歷輸出:"); PreOrderTraverse_re(T,print); printf("\n中序非遞歸遍歷輸出:"); InOrderTraverse(T,print); printf("\n前序非遞歸遍歷輸出:"); PreOrderTraverse(T,print); printf("\n"); break; case 2: printf("前序遞歸創(chuàng)建二叉樹〔空格 表示此結點為空〕:\n"); getchar(); Creat
56、eBiTree(T); printf("\n中序遍歷線索化二叉樹:"); InOrderThreading(Thrt , T); InOrderTraverse_Thr(Thrt , print); break; case 3: printf("前序遞歸創(chuàng)建二叉樹〔空格 表示此結點為空〕:\n"); getchar(); CreateBiTree(T); printf("\n按層遍歷輸出:"); Levelorder(T); printf("\n"); break; defa
57、ult:return; }*/ printf("前序遞歸創(chuàng)建二叉樹〔空格 表示此結點為空〕:\n"); getchar(); CreateBiTree(T); printf("中序遞歸遍歷輸出:"); InOrderTraverse_re(T,print); printf("\n前序遞歸遍歷輸出:"); PreOrderTraverse_re(T,print); printf("\n中序非遞歸遍歷輸出:"); InOrderTraverse(T,print); printf("\n前序非遞歸遍歷輸出:"); PreOrderTraverse(T,print); printf("\n按層遍歷輸出:"); Levelorder(T); printf("\n中序遍歷線索化二叉樹:"); InOrderThreading(Thrt , T); InOrderTraverse_Thr(Thrt , print); printf("\n"); while(1); return; } 20 / 20
- 溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
5. 裝配圖網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。