Cấu trúc dữ liệu và giải thuật (Đỗ Tuấn Anh) - Chương 3. Mảng và danh sách
lượt xem 40
download
Ma trận (mảng 2 chiều) là một mảng màmỗi phần tử là một mảng một chiều C lưu trữ mảng nhiều chiều theo thứ tự ưu tiên hàng–mỗi phần tửlàmột hàng Mảng nhiều chiều vẫn được lưu trữ kếtiếp như mảng một chiều.
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 và giải thuật (Đỗ Tuấn Anh) - Chương 3. Mảng và danh sách
- Cấu trúc dữ liệu và giải thuật Đỗ Tuấn Anh Email: anhdt@it-hut.edu.vn
- Nội dung Chương 1 – Thiết kế và phân tích (5 tiết) Chương 2 – Giải thuật đệ quy (10 tiết) Chương 3 – Mảng và danh sách (5 tiết) Chương 4 – Ngăn xếp và hàng đợi (10 tiết) Chương 5 – Cấu trúc cây (10 tiết) Chương 8 – Tìm kiếm (5 tiết) Chương 7 – Sắp xếp (10 tiết) Chương 6 – Đồ thị (5 tiết)
- Chương 3 – Mảng và Danh sách 1. Mảng 2. Danh sách 3. Một số phép toán trên danh sách nối đơn 4. Các dạng khác của danh sách móc nối 5. Sử dụng danh sách móc nối – Ví dụ bài toán cộng đa thức
- 1. Mảng Mảng: Số phần tử cố đinh Kích thước một phần tử cố định Các phần tử mảng phải cùng kiểu Truy cập ngẫu nhiên (theo chỉ số)
- Mảng: Số phần tử cố định Kích thước mảng sau khi khai báo là cố định Ví dụ: void notAllowed (); { int size; int arr[size]; /* không được phép, kích thước mảng phải là hằng số xác định*/ printf(“Enter the size of the array: “); scanf(“%d”, &size); }
- Cấu trúc lưu trữ của mảng double x[50]; … x[0] x[1] x[2] x[3] x[49] addr addr + 49 * sizeof(double) Mảng được lưu trữ kế tiếp => truy cập ngẫu nhiên sử dụng chỉ số => tốc độ truy cập tất cả các phần tử là như nhau
- Mảng nhiều chiều double a[5][5]; Ma trận (mảng 2 chiều) là a[0] a[0][0] a[0][1] a[0][2] a[0][4] một mảng mà mỗi phần tử là một mảng một chiều a[1] a[1][0] a[1][1] C lưu trữ mảng nhiều chiều theo thứ tự ưu tiên hàng – mỗi phần tử là một hàng a[4][4] a[4] a[4][0] Mảng nhiều chiều vẫn được lưu trữ kế tiếp như mảng một chiều … a[0][0] a[0][1] a[0][2] a[0][3] a[0][4] a[4][3] a[4][4] addr addr + (i*5+j)*sizeof(double)
- 2. Danh sách Danh sách những người đến khám bệnh Ban đầu chưa có ai Có người mới đến Có người khám xong đi về (Tạo hình ảnh động tại đây)
- Danh sách tuyến tính Một chuỗi các phần tử Tồn tại phần tử đầu và phần tử cuối Mỗi phần tử có phần tử trước và phần tử sau
- Danh sách tuyến tính Số phần tử biến đổi Một phần tử thường là một cấu trúc (struct) Thao tác thường xuyên nhất Thêm phần tử Xóa phần tử Các thao tác khác: Tìm kiếm Ghép 2 danh sách Tách 1 danh sách thành nhiều danh sách Sao chép danh sách Cập nhật
- Phân loại danh sách tuyến tính Nguồn: Data Structures : A Pseudocode Approach With C by Richard F. Gilberg, Behrouz A. Forouzan
- Thêm một phần tử mới
- Tìm một phần tử
- Xóa một phần tử khỏi danh sách
- Lưu trữ danh sách liên kết 1. Lưu trữ kế tiếp sử dụng mảng 2. Lưu trữ móc nối
- 2.1 Danh sách - Lưu trữ kế tiếp Sử dụng mảng 1 chiều Tìm kiếm dễ dàng (tuần tự hoặc tìm kiếm nhị phân) Duyệt các phần tử dễ dàng sử dụng chỉ số: for(i = 0; i Không biết trước số phần tử
- Lưu trữ kế tiếp - Thêm một phần tử 123 Thêm một phần tử thứ i vào 125 mảng 135 155 - Chuyển các phần tử i 161 i->n xuống các vị trí 165 166 i+1 ->n+1 i+1 167 - Thêm phần tử cần 167 thêm vào vị trí thứ i 169 n 177 178 n+1
- Lưu trữ kế tiếp - Xóa một phần tử 123 Xóa một phần tử thứ i khỏi 125 mảng 135 - Chuyển các phần tử 155 i+1->n vào các vị trí i 161 i ->n-1 166 i+1 167 167 169 n-1 177 n 178
- Không hiệu quả Việc lưu trữ liên tiếp ⇒ thao tác thêm và xóa không hiệu quả (dịch chuyển phần tử). 7 21 56 43 22 xóa 21 n/2 lần dịch chuyển (trung bình) 7 56 43 22 Thời gian tính: O(n) Thêm 67 sau 56 Các thao tác thêm và xóa có thời 7 56 67 43 22 gian chạy là O(n).
- Lưu trữ kế tiếp Ưu điểm: truy cập nhanh (ngẫu nhiên, thời gian truy cập mọi phần tử là như nhau) Nhược điểm: Việc thêm, bớt phần tử rất khó khăn (phải dịch chuyển nhiều phần tử khác) Tốn bộ nhớ, cấp phát nhiều hơn cần thiết để giữ chỗ
CÓ THỂ BẠN MUỐN DOWNLOAD
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 1 - Trần Thị Kim Chi
180 p | 145 | 19
-
Bài giảng Cấu trúc dữ liệu - Bài 1:Tổng quan về cấu trúc dữ liệu và giải thuật
47 p | 179 | 17
-
Bài giảng Cấu trúc dữ liệu và giải thuật trong C++ - Bài 8: Cấu trúc dữ liệu ngăn xếp
28 p | 81 | 9
-
Bài giảng Cấu trúc dữ liệu và giải thuật - Chương 1: Các khái niệm cơ bản về Cấu trúc dữ liệu và giải thuật
20 p | 47 | 8
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 1 - Trần Minh Thái (Trường Đại học Hồng Bàng )
62 p | 173 | 6
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 1 - Trần Minh Thái (2016)
62 p | 94 | 6
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Cấu trúc dữ liệu cây AA - Bùi Tiến Lên
30 p | 35 | 6
-
Bài giảng Cấu trúc dữ liệu và giải thuật - Chương 1: Một số khái niệm cơ bản về cấu trúc dữ liệu và giải thuật
12 p | 92 | 4
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Tổng quan - Nguyễn Đức Cương
6 p | 100 | 4
-
Bài giảng Cấu trúc dữ liệu và giải thuật – Chương 1: Tổng quan về giải thuật và cấu trúc dữ liệu
10 p | 70 | 4
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 7 - Châu Thị Bảo Hà
133 p | 115 | 4
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 1 - Th.S Thiều Quang Trung
44 p | 93 | 4
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 1 – Trần Minh Thái (2017)
67 p | 107 | 4
-
Bài giảng Cấu trúc dữ liệu và giải thuật – Bài 1: Giới thiệu chung
40 p | 56 | 4
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Bài 1b - Hoàng Thị Điệp (2014)
29 p | 30 | 3
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 1 - Ths. Phạm Thanh An (2018)
67 p | 65 | 3
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 1 - Ngô Quang Thạch
49 p | 64 | 3
-
Bài giảng Cấu trúc dữ liệu và giải thuật: Chương 2 - Th.S Thiều Quang Trung
41 p | 70 | 3
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