1. Trang chủ
  2. » Công Nghệ Thông Tin

Bài giảng - Cấu trúc dữ liệu pot

84 348 0

Đang tải... (xem toàn văn)

Tài liệu hạn chế xem trước, để xem đầy đủ mời bạn chọn Tải xuống

THÔNG TIN TÀI LIỆU

Thông tin cơ bản

Định dạng
Số trang 84
Dung lượng 1,16 MB

Nội dung

 TR :           :   : 17207 TRÌNH :  DÙNG CHO SV NGÀNH :  - 2008 i 11.7.    2     CNTT  : 3       60 30 30 0 0 0  Sinh      -  -  -  -  -  -     TS LT TH/Xemina BT KT Ch 2 2 0       12 6 6 2.1. Danh sách  2.1.2. Các phép toán trên danh sách    (stack)          III: Cây (tree). 18 9 8 1  ii   TS LT TH/Xemina BT KT       3.3.2. L       search tree)  3.5.2. Cây AVL  I 14 7 6 1          Cấu trúc dữ liệu và thuật toán,  2004.  Cấu trúc dữ liệu và giải thuật 2004. 3. Robert Sedgewick, Cẩm nang thuật toán 2000.  -  -    1 CHCÁC           toán.     ng                trong máy tính chín                 Kh trong        2 -   - P  mô hình thích hợp thức hoá một giải thuật, một cấu trúc dữ liệu    ràng, nó   kiểu dữ liệu    Newclr    void GREEDY ( GRAPH *G, SET *Newclr ) { Newclr = ; /*1*/  clr) /*3*/ {  thêm v vào Newclr; /*5*/ } }   i báo thích   if   void GREEDY ( GRAPH *G, SET *Newclr ) { Newclr= ; /*1*/  { int found=0; /*3.1*/   found=1; /*3.4*/ if (found==0)/*3.5*/ {  thêm v vào Newclr; /*5*/ } } }  3     void GREEDY ( GRAPH *G, LIST *Newclr ) { int found; int v,w ; Newclr= ;  trong G; while (v<>null) { found=0;  while( w<>null) && (found=0) {  found=1;  } if (found==0 ) {  Thêm v vào Newclr; }  } }  (abstract data types ADT). ng hóa    ng hóa chng trình                        bao gói.  là: void main() { Nhap(Lop); Xu_ly (Lop); Xuat (Lop); } 4         Một kiểu dữ liệu trừu tng là một mô hình toán học cùng với một tập hợp các phép toán (operator) trừu tng c định nghĩa trên mô hình đó  nguyên cùng      ADT là sự tổng quát hoá của các kiểu dữ liệu nguyên thỷ.    -  -  -   -     MAKENULL(newclr) newclr=; w=FIRST(newclr)  w=NEXT(w,newclr)  INSERT( v,newclr) Thêm v vào newclr  ý                                    -                        5   -             1.   2.   6  2.1. Danh sách    các p 1 , a 2 , . . ., a n   1  n     i  i+1 -  i  i-1  i    1.  2.  3.  4.  5.    2.1.2. Các phép toán trên danh sách            INSERT_LIST(x,p,L):    position)  1 , a 2 , . , a p-1 , a p ,. . , a n  a 1 , a 2 , . . ., a p-1 , x, a p , . . . , a n   LOCATE(x,L)      L.                       ENDLIST(L). RETRIEVE(p,L)       DELETE_LIST(p,L)                 NEXT(p,L)         PREVIOUS(p,L)     p trong danh   FIRST(L)    7   EMPTY_LIST(L)    FALSE. MAKENULL_LIST(L)           void SORT(LIST L) {   while (p!=ENDLIST(L)) {  while (q!=ENDLIST(L)) { if (RETRIEVE(p,L) > RETRIEVE(q,L))  q=NEXT(q,L); } p=NEXT(p,L); } }        INSERT_LIST(x,p,L) có 3 th        a.   dùng một mảng ể lưu giữ liên tiếp các phần tử của danh sách từ vị trí đầu tiên của mảng       Ta định nghĩa vị trí của một phần tử trong danh sách là chỉ số của mảng tại vị trí lưu trữ phần tử đó + 1(vì phần tử đầu tiên trong mảng là chỉ số 0). [...]... (Empty_Queue(*Q)) Q->Front=0; if (Q->Rear==MaxLength-1) { //Di chưyen tinh tien ra trước Front -1 vi tri for(int i=Q->Front;iRear;i++) Q->Elements[i-Q->Front]=Q->Elements[i]; //Xac dinh vi tri Rear moi Q->Rear=MaxLength - Q->Front-1; Q->Front=0; } //Tăng Rear de lưu noi dung moi Q->Rear=Q->Rear+1; Q->Element[Q->Rear]=X; } else printf("Loi: Hàng day!"); } b Cài đặt hàng với mảng xoay vòng Maxlength-1 rear... 2 P->previous P p->next Hình II.16 Xóa phần tử tại vị trí p Nếu (p->previous!=NULL) thì p->previous->next=p->next; Nếu (p->next!=NULL) thì p->next->previous=p->previous; Xoá ô đang được trỏ bởi DL, tức là p=DL: ngoài việc cập nhật lại các con trỏ để nối kết các ô trước và sau p ta còn phải cập nhật lại DL, ta có thể cho DL trỏ đến phần tử trước nó (DL = p->Previous) hoặc đến phần tử sau nó (DL = p->Next)... X,Position p, DoubleList *DL) 21 { if (*DL == NULL) { (*DL)=(Node*)malloc(sizeof(Node)); (*DL )-> Element = X; (*DL )-> Previous =NULL; (*DL )-> Next =NULL; } else{ Position temp; temp=(Node*)malloc(sizeof(Node)); temp->Element=X; temp->Next=p; temp->Previous=p->Previous; if (p->Previous!=NULL) p->Previous->Next=temp; p- >Previous=temp; } } 2.2 Ngăn xếp (stack) 2.2.1 Khái niệm Ngăn xếp (Stack) là một danh sách... ra khỏi hàng, vì vậy hàng còn được gọi là cấu trúc FIFO (first in - first out) hay "vào trước - ra trước" Các phép toán co bản trên hàng - MAKENULL_QUEUE(Q) khởi tạo một hàng rỗng - FRONT(Q) hàm trả về phần tử đầu tiên của hàng Q - ENQUEUE(x,Q) thêm phần tử x vào cuối hàng Q - DEQUEUE(Q) xoá phần tử tại đầu của hàng Q - EMPTY_QUEUE(Q) hàm kiểm tra hàng rỗng 28 - FULL_QUEUE(Q) kiểm tra hàng đầy 2.3.2... ((PL->Last+1)) printf("Vi tri khơng hop le"); else{ Position Q; /*Dời các phần tử từ vị trí p (chỉ số trong mảng là p-1) đến cuối danh sách sang phải 1 vị trí*/ for(Q=(L->Last-1)+1;Q>P-1;Q ) L->Elements[Q]=L->Elements[Q-1]; //Ðưa x vào vị trí p L->Elements[P-1]=X; L->Last++;//Tăng độ dài danh sách lên 1 } } Xóa phần tử ra khỏi danh sách Xoá một phần tử ở vị trí p ra khỏi danh sách L ta làm... DL=(Node*)malloc(sizeof(Node)); DL->Element = x; DL->Previous=NULL; DL->Next =NULL; Nếu DL!=NULL, sau khi thêm phần tử x vào vị trí p ta có kết quả như hình II.18 H Y P P->previous p->next ình II.1 7 Dan h sác h trước khi thêm phần tử X X P->previous Y P p->next Hình II.18: Danh sách sau khi thêm phần tử x vào tại vị trí p (phần tử tại vị trí p cũ trở thành phần tử "sau" của x) Lưu ý: các kí hiệu p, p->Next, p->Previous... Ðặc biệt, nếu danh sách chỉ có một phần tử tức là p->Next=NULL và p>Previous=NULL thì DL=NULL void Delete_List (Position p, DoubleList *DL) 20 { if (*DL == NULL) printf(”Danh sach rong”); else { if (p==*DL) (*DL)=(*DL )-> Next; //Xóa phần tử đầu tiên của danh sách nên phải thay dổi DL else p->Previous->Next=p->Next; if (p->Next!=NULL) p->Next->Previous=p->Previous; free(p); } } Thêm phần tử vào danh sách... định nội dung phần tử: Nội dung phần tử đang lưu trữ tại vị trí p trong danh sách L là p->next->Element Do đó, hàm sẽ trả về giá trị p->next->element nếu phần tử có tồn tại, ngược lại phần tử không tồn tại (p->next=NULL) thì hàm không xác định ElementType Retrieve(Position P, List L) { if (P->Next!=NULL) return P->Next->Element; } Hãy thiết kế hàm Locate bằng cách sử dụng các phép toán trừu tượng co bản... trường dữ liệu của ô này là rỗng, chỉ có trường con trỏ Next trỏ tới ô chứa phần tử đầu tiên thật sự của danh sách Nếu danh sách rỗng thì Header->next trỏ tới NULL Việc cấp phát ô nhớ cho Header như là một ô chứa dữ liệu bình thường nhằm tăng tính đơn giản của các giải thuật thêm, xoá các phần tử trong danh sách Ở đây, ta cần phân biệt rõ giá trị của một phần tử và vị trí (position) của nó trong cấu trúc. .. 1 phần tử) void Delete_List(Position P,List *L) { if ((PL->Last)) printf("Vi tri khơng hop le"); else if (EmptyList(*L)) printf("Danh sach rong!"); else{ Position Q; /*Dời các phần tử từ vị trí p+1 (chỉ số trong mảng là p) đến cuối danh sách sang trái 1 vị trí*/ for(Q=P-1;QLast-1;Q++) L->Elements[Q]=L->Elements[Q+1]; L->Last ; } } Ðịnh vị một phần tử trong danh sách Ðể định vị vị trí .  -   for(Q=(L->Last-1)+1;Q>P-1;Q ) L->Elements[Q]=L->Elements[Q- L->Elements[P-1]=X; L-.     Cấu trúc dữ liệu và thuật toán,  2004.  Cấu trúc dữ liệu và giải thuật 2004   -  -  -  -  -  -  

Ngày đăng: 04/07/2014, 01:20

HÌNH ẢNH LIÊN QUAN

Hình thức và tiêu chuẩn đánh giá sinh viên: - Bài giảng - Cấu trúc dữ liệu pot
Hình th ức và tiêu chuẩn đánh giá sinh viên: (Trang 3)
Hình b3: Xóa một phần tử tại vị trí p - Bài giảng - Cấu trúc dữ liệu pot
Hình b3 Xóa một phần tử tại vị trí p (Trang 17)
Hình d.1 Mảng đang chứa hai danh sách L 1  và L 2 - Bài giảng - Cấu trúc dữ liệu pot
Hình d.1 Mảng đang chứa hai danh sách L 1 và L 2 (Trang 19)
Hình II.15 Hình ảnh một danh sách liên kết kép - Bài giảng - Cấu trúc dữ liệu pot
nh II.15 Hình ảnh một danh sách liên kết kép (Trang 22)
Hình II.16 Xóa phần tử tại vị trí p - Bài giảng - Cấu trúc dữ liệu pot
nh II.16 Xóa phần tử tại vị trí p (Trang 23)
Hình II.18: Danh sách sau khi thêm phần tử x vào tại vị trí p (phần tử tại vị trí p cũ trở  thành phần tử &#34;sau&#34; của x) - Bài giảng - Cấu trúc dữ liệu pot
nh II.18: Danh sách sau khi thêm phần tử x vào tại vị trí p (phần tử tại vị trí p cũ trở thành phần tử &#34;sau&#34; của x) (Trang 24)
Hình II.12 Cài đặt hàng bằng mảng xoay vòng - Bài giảng - Cấu trúc dữ liệu pot
nh II.12 Cài đặt hàng bằng mảng xoay vòng (Trang 34)
Hình 5.2. Cây, tham khảo từ wikipedia - Bài giảng - Cấu trúc dữ liệu pot
Hình 5.2. Cây, tham khảo từ wikipedia (Trang 40)
Hình  III.1  -  Cây mục lục một quyển sách - Bài giảng - Cấu trúc dữ liệu pot
nh III.1 - Cây mục lục một quyển sách (Trang 41)
Hình  III.2:  Hai cây có thứ tự khác nhau - Bài giảng - Cấu trúc dữ liệu pot
nh III.2: Hai cây có thứ tự khác nhau (Trang 42)
Hình minh họa: - Bài giảng - Cấu trúc dữ liệu pot
Hình minh họa: (Trang 44)
Hình 5.6. Cây tìm kiếm nhi ̣ phân, tham khảo từ wikipedia  Duyê ̣t thứ tự trước (pre-order traversal): - Bài giảng - Cấu trúc dữ liệu pot
Hình 5.6. Cây tìm kiếm nhi ̣ phân, tham khảo từ wikipedia Duyê ̣t thứ tự trước (pre-order traversal): (Trang 46)
Hình vẽ dưới đây minh họa phép quay kép áp dụng cho trường hợp này: - Bài giảng - Cấu trúc dữ liệu pot
Hình v ẽ dưới đây minh họa phép quay kép áp dụng cho trường hợp này: (Trang 56)
CHƯƠNG 4. BẢNG BĂM (HASH TABLE) - Bài giảng - Cấu trúc dữ liệu pot
4. BẢNG BĂM (HASH TABLE) (Trang 65)
Bảng băm hình chữ nhật được mô tả bởi một danh sách kề : - Bài giảng - Cấu trúc dữ liệu pot
Bảng b ăm hình chữ nhật được mô tả bởi một danh sách kề : (Trang 67)
Hình  2.3  :  Bảng  băm  theo  phương pháp móc nối - Bài giảng - Cấu trúc dữ liệu pot
nh 2.3 : Bảng băm theo phương pháp móc nối (Trang 79)

TỪ KHÓA LIÊN QUAN

w