CẤU TRÚC DỮ LIỆU ĐỘNG
lượt xem 13
download
Được khai báo tường minh, có tên gọi Tồn tại trong phạm vi khai báo Được cấp phát trong stack Kích thước không đổi = không tận...
Bình luận(0) Đăng nhập để gửi bình luận!
Nội dung Text: CẤU TRÚC DỮ LIỆU ĐỘNG
- NỘI DUNG CẤU TRÚC DỮ LIỆU ĐỘNG Cấu trúc dữ liệu 1
- Biến tĩnh Được khai báo tường minh, có tên gọi Tồn tại trong phạm vi khai báo Được cấp phát trong stack Kích thước không đổi => không tận dụng hiệu quả bộ nhớ • Ví dụ : int x,y; char c; Cấu trúc dữ liệu 1 float f[5]; • Khi biết chắc nhu cầu sử dụng đối tượng trước khi thực sự xử lý : dùng biến không động
- Ví dụ hạn chế của biến tinh • Tổ chức danh sách lớp học • Dùng mảng tĩnh : typedef struct { char ten[20]; int maso; }Hocvien; Hocvien danhsach[50]; Cấu trúc dữ liệu 1 • Số lượng học viên lãng phí • Số lượng học viện > 50 => thiếu chỗ !
- Biến dộng Không được khai báo tường minh, không có tên gọi Xin khi cần, giải phóng khi sử dụng xong Được cấp phát trong heap Linh động về kích thước Vấn đề : biến động không có tên gọi Cấu trúc dữ liệu 1 tường minh, làm sao thao tác ?
- Kiểu con trỏ Kiểu con trỏ dùng lưu địa chỉ của một đối tượng dữ liệu khác. Biến thuộc kiểu con trỏ Tp là biến mà giá trị của nó là địa chỉ cuả một vùng nhớ ứng với một biến kiểu T, hoặc là giá trị NULL. Khai báo trong C : *intpointer; typedef int p; intpointer Cấu trúc dữ liệu 1 Bản thân biến con trỏ là không động Dùng biến con trỏ để lưu giữ điạ chỉ của biến động = truy xuất biến động thông qua biến con >
- Các thao tác trên kiểu con trỏ Tạo ra một biến động và cho con trỏ ‘p’ chỉ đến nó: – void* malloc(size); – void* calloc(n,size); – new // hàm cấp phát bộ nhớ trong C++ Hủy một biến động do p chỉ đến : – Hàm free(p) huỷ vùng nhớ cấp phát bởi hàm Cấu trúc dữ liệu 1 malloc hoặc calloc do p trỏ tới – Hàm delete p huỷ vùng nhớ cấp phát bởi hàm new do p trỏ tới
- Sử dụng biến tinh, con trỏ và biến động Biến không động x int x; x=5; 5 Biến con trỏ p int *p; 0xFF p = new(int); *p = 5 0xFF Cấu trúc dữ liệu 1 5 Bieán ñoäng coù ñòa chæ 0xFF
- Kiểu danh sách Danh sách ={ các phần tử có cùng kiểu} Danh sách là một kiểu dữ liệu tuyến tính : – Mỗi phần tử có nhiều nhất 1 phần tử đứng trước – Mỗi phần tử có nhiều nhất 1 phần tử đứng sau Là kiểu dữ liệu quen thuộc trong thực tế : – Danh sách học sinh Cấu trúc dữ liệu 1 – Danh mục sách trong thư viện – Danh bạ điện thoại – Danh sách các nhân viên trong công ty
- Các hình thức tổ chức danh sách CTDL cho mỗi phần tử ? Thể hiện liên kết của các phần tử ? Hai hình thức cơ bản : – Liên kết ngầm : Mảng Cấu trúc dữ liệu 1 – Liên kết tường minh : Danh sách liên kết
- Danh sách liên kết ngầm(mảng) Mối liên hệ giữa các phần tử được thể hiện ngầm: – xi : phần tử thứ i trong danh sách x0 … xi xi+1 – xi , xi+1 là kế cận trong danh sách Phải lưu trữ liên tiếp các phần tử trong bộ nhớ – công thức xác định địa chỉ phần tử thứ i: address(i) = address(1) + (i-1)*sizeof(T) Ưu điểm : Truy xuất trực tiếp, nhanh chóng Nhược điểm: - Sử dụng bộ nhớ kém hiệu quả Cấu trúc dữ liệu 1 - Kích thước cố định - Các thao tác thêm vào , loại bỏ không hiệu quả
- Liên kết tuờng minh(Danh sánh liên kết) • CTDL cho một phần tử : – Thông tin bản thân – Địa chỉ của phần tử kế trong danh sách x2 x0 x3 x1 Mỗi phần tử là một biến động Cấu trúc dữ liệu 1 Ưu điểm + Sử dụng hiệu quả bộ nhớ + Linh động về số lượng phần tử
- Các loại danh sách liên kết • Danh sách liên kết đơn: Mỗi phần tử liên kết với phần tử đứng sau nó trong danh sách A B C D • Danh sách liên kết kép: Mỗi phần tử liên kết với phần tử đứng trước và sau nó trong danh sách A B C D Cấu trúc dữ liệu 1 • Danh sách liên Vòng: Phần tử cuối danh sách liên với phần tử đầu danh sách
- Các loại danh sách liên kết (tt) Danh sách liên Vòng: Phần tử cuối danh sách • liên với phần tử đầu danh sách – Danh sách liên kết đơn vòng A B C D – Danh sách liên kết đôi vòng Cấu trúc dữ liệu 1 A B C D
CÓ THỂ BẠN MUỐN DOWNLOAD
-
CẤU TRÚC DỮ LIỆU & GIẢI THUẬT
9 p | 99 | 11
-
Đề thi kết thúc học phần học kì 1 môn Cấu trúc dữ liệu và giải thuật năm 2020-2021 có đáp án - Trường ĐH Đồng Tháp
4 p | 89 | 11
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 3 - ThS. Trịnh Quốc Sơn (ĐH Công nghệ Thông tin)
13 p | 70 | 9
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Hàng đợi ưu tiên - Nguyễn Mạnh Hiển (HKI năm 2020-2021)
25 p | 52 | 6
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 6 - Trường ĐH Văn Lang
39 p | 22 | 6
-
Bài giảng Cấu trúc dữ liệu: Ngôn ngữ lập trình C++ - TS. Lê Minh Trung & Th.S Lương Trần Ngọc Khiết
71 p | 38 | 6
-
Bài giảng Cấu trúc dữ liệu và giải thuật - Chương 5: Bảng băm
6 p | 86 | 5
-
Bài giảng Cấu trúc dữ liệu và giải thuật 1: Chương 3
13 p | 40 | 5
-
Bài giảng Cấu trúc dữ liệu 1: Chương 4 - Lương Trần Hy Hiến
17 p | 94 | 5
-
Chapter 4: Cấu trúc dữ liệu động
12 p | 89 | 5
-
Bài giảng Cấu trúc dữ liệu và thuật toán: Chương 4 - Cấu trúc dữ liệu cơ bản
26 p | 13 | 4
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 3 - Trường ĐH Công nghệ Thông tin
14 p | 23 | 4
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Bảng băm - Bùi Tiến Lên
51 p | 27 | 4
-
Bài giảng Cấu trúc dữ liệu và giải thuật 1: Chương 1
30 p | 27 | 4
-
Đề cương chi tiết học phần Cấu trúc dữ liệu và giải thuật (Data structures and algorithms)
10 p | 43 | 3
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 2.3 - TS. Nguyễn Thị Kim Thoa
34 p | 12 | 3
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Bài toán chọn hoạt động
4 p | 20 | 2
-
Bài giảng Cấu trúc dữ liệu 1: Giới thiệu - Huỳnh Cao Thế Cường
10 p | 51 | 2
Chịu trách nhiệm nội dung:
Nguyễn Công Hà - Giám đốc Công ty TNHH TÀI LIỆU TRỰC TUYẾN VI NA
LIÊN HỆ
Địa chỉ: P402, 54A Nơ Trang Long, Phường 14, Q.Bình Thạnh, TP.HCM
Hotline: 093 303 0098
Email: support@tailieu.vn