Đang chuẩn bị nút TẢI XUỐNG, xin hãy chờ
Tải xuống
const int max_chars = 28; template void Sortable_list :: radix_sort( ) { Record data; Queue queues[max_chars]; for (int position = key_size − 1; position = 0; position−−) { // Loop from the least to the most significant position. while (remove(0, data) == success) { int queue_number = alphabetic_order(data.key_letter(position)); queues[queue_number].append(data); // Queue operation. . | CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Chương 9: Bảng Ma trận 2 chiều vs. 1 chiều A[i, j] B[ max_row*i + j] C[i + max_col*j] Chương 9: Bảng Bảng và chỉ mục Chương 9: Bảng Radix sort r a t m o p c a t m a p c a r t o p c o t t a r r a p Bước 1 r a t m o p c a t m a p c a r t o p c o t t a r r a p r a t m o p c a t m a p c a r t o p c o t t a r r a p r a t m o p c a t m a p c a r t o p c o t t a r r a p Bước 2 Bước 3 Chương 9: Bảng Đánh giá Radix sort Số lần so sánh là Θ(n k), n là số phần tử và k là số ký tự trên khóa So sánh với các phương pháp khác là n lg n: Nếu k lớn và n là nhỏ thì radix sort chậm Nếu k nhỏ và n là lớn thì radix sort nhanh hơn Bất tiện: Việc tách thành 27 danh sách con và ghép lại lúc sau trên DS liên tục gây ra việc di chuyển nhiều phần tử Khóa so sánh là chuỗi nhị phân thì không tốt Chương 9: Bảng Radix sort trên DSLK Chương 9: Bảng Giải thuật Radix sort trên DSLK Algorithm radix_sort Input: danh sách cần sắp thứ tự Output: danh sách đã sắp thứ tự //Mỗi queue chứa các phần tử có ký tự tương ứng 1. queues là một dãy có max_character hàng //Lặp k bước, kiểm tra các ký tự tại vị trí k 2. for position = size(khóa) to 0 2.1. while (danh sách còn) 2.1.1. Lấy phần tử đầu tiên 2.1.2. Tính toán thứ tự của chữ cái ở vị trí k trong khóa 2.1.3. Đẩy phần tử này vào queue tương ứng 2.2. Nối tất cả các queue lại với nhau thành danh sách End radix_sort Chương 9: Bảng Mã C++ Radix sort trên DSLK const int max_chars = 28; template void Sortable_list :: radix_sort( ) { Record data; Queue queues[max_chars]; for (int position = key_size − 1; position >= 0; position−−) { // Loop from the least to the most significant position. while (remove(0, data) == success) { int queue_number = alphabetic_order(data.key_letter(position)); queues[queue_number].append(data); // Queue operation. } rethread(queues); // Reassemble the list. } } Chương 9: Bảng Nối các queue liên kết Cách 1: Dùng các CTDL queue Phải dùng queue.retrieve và . | CẤU TRÚC DỮ LIỆU VÀ GIẢI THUẬT Chương 9: Bảng Ma trận 2 chiều vs. 1 chiều A[i, j] B[ max_row*i + j] C[i + max_col*j] Chương 9: Bảng Bảng và chỉ mục Chương 9: Bảng Radix sort r a t m o p c a t m a p c a r t o p c o t t a r r a p Bước 1 r a t m o p c a t m a p c a r t o p c o t t a r r a p r a t m o p c a t m a p c a r t o p c o t t a r r a p r a t m o p c a t m a p c a r t o p c o t t a r r a p Bước 2 Bước 3 Chương 9: Bảng Đánh giá Radix sort Số lần so sánh là Θ(n k), n là số phần tử và k là số ký tự trên khóa So sánh với các phương pháp khác là n lg n: Nếu k lớn và n là nhỏ thì radix sort chậm Nếu k nhỏ và n là lớn thì radix sort nhanh hơn Bất tiện: Việc tách thành 27 danh sách con và ghép lại lúc sau trên DS liên tục gây ra việc di chuyển nhiều phần tử Khóa so sánh là chuỗi nhị phân thì không tốt Chương 9: Bảng Radix sort trên DSLK Chương 9: Bảng Giải thuật Radix sort trên DSLK Algorithm radix_sort Input: danh sách cần sắp thứ tự Output: danh sách đã sắp thứ tự .