Thuật Toán Sắp Xếp Chèn (Insertion Sort) - DNMTechs

Skip to content

Sắp xếp chèn (insertion sort) là một thuật toán sắp xếp bắt chước cách sắp xếp quân bài của những người chơi bài. Muốn sắp một bộ bài theo trật tự người chơi bài rút lần lượt từ quân thứ 2, so với các quân đứng trước nó để chèn vào vị trí thích hợp. Ở đây, một danh sách con (hoặc một mảng) luôn luôn được duy trì dưới dạng đã qua sắp xếp tại một thời điểm. Sắp xếp chèn là chèn thêm một phần tử vào danh sách con đã qua sắp xếp. Phần tử được chèn vào vị trí thích hợp sao cho vẫn đảm bảo rằng danh sách con đó vẫn sắp theo thứ tự.

Với cấu trúc dữ liệu mảng, hãy tưởng tượng nó gồm hai phần: một danh sách con đã được sắp xếp phần khác là các phần tử không có thứ tự chưa được sắp xếp. Giải thuật sắp xếp chèn sẽ thực hiện việc tìm kiếm liên tiếp qua mảng đó, và các phần tử không có thứ tự sẽ được di chuyển và được chèn vào vị trí thích hợp trong danh sách con (của cùng mảng đó).

Nó ít hiệu quả hơn khi sử dụng đối với các danh sách lớn so các thuật toán nâng cao như quicksort , heapsort , hoặc merge sort . Tuy nhiên, sắp xếp chèn cũng có một số ưu điểm:

  • Triển khai đơn giản
  • Hiệu quả cho các tập dữ liệu nhỏ (vừa), giống như các thuật toán sắp xếp bậc hai khác
  • Hiệu quả hơn trong thực tế so với hầu hết các giải thuật bậc hai đơn giản khác (tức là, các thuật toán có thời gian tính O(n2)) như sắp xếp chọn hoặc sắp xếp nổi bọt
  • Thích ứng (Adaptive): hiệu quả cho các tập dữ liệu đã được sắp xếp đáng kể, độ phức tạp thời gian là O(nk) khi mỗi phần tử trong đầu vào không quá k vị trí so với vị trí được sắp xếp của nó
  • Ổn định (Stable): tức là không thay đổi thứ tự tương đối của các phần tử với các khóa bằng nhau
  • in-place (Tìm In-place algorithm): tức là chỉ yêu cầu một lượng không đổi O(1) của không gian bộ nhớ bổ sung
  • Trực tuyến (Online) tức là, có thể sắp xếp một danh sách ngay khi nó nhận được nó

Phân loại: Sắp xếp chèn Cấu trúc dữ liệu: Cấu trúc dữ liệu mảng Phức tạp thời gian: О(n2) Phức tạp dữ liệu: О(n) tổng, O(1) phụ Tối ưu: Không có

Các bước của giải thuật sắp xếp chèn (Insertion Sort)

Bước 1: Kiểm tra nếu phần tử đầu tiên đã được sắp xếp. trả về 1 Bước 2: Lấy phần tử kế tiếp Bước 3: So sánh với tất cả phần tử trong danh sách con đã qua sắp xếp Bước 4: Dịch chuyển tất cả phần tử trong danh sách con mà lớn hơn giá trị để được sắp xếp Bước 5: Chèn giá trị đó Bước 6: Lặp lại cho tới khi danh sách được sắp xếp

Ví dụ: Sắp xếp một mảng gồm 8 phần tử theo thứ tự tăng dần bằng thuật toán sắp xếp chèn:

Cơ sở của thuật toán

Cơ sở lập luận của sắp xếp chèn có thể mô tả như sau: Xét danh sách con gồm k phần tử đầu a1, …,ak. Với k = 1, danh sách gồm một phần tử đã được sắp. Giả sử trong danh sách k-1 phần tử đầu a1, …,ak-1 đã được sắp. Để sắp xếp phần tử ak = x ta tìm vị trí thích hợp của nó trong dãy a1, …,ak-1. Vị trí thích hợp đó là đứng trước phần tử lớn hơn nó và sau phần tử nhỏ hơn hoặc bằng nó.

Ví dụ: Viết thuật toán sắp xếp chèn bằng ngôn ngữ C++.

#include<iostream> using namespace std; void input_func(int A[], int &n) { cout << "nhap so phan tu cua mang n:"; cin >> n; for (int i = 0; i<n; i++) { cout << "phan tu A[" << i << "]" << "="; cin >> A[i]; } } void InsertSort(int A[], int n) { int t, j; for (int i = 1; i<n; i++) { j = i - 1; t = A[i]; while (t<A[j] && j >= 0) { A[j + 1] = A[j]; j--; } A[j + 1] = t; } } void output_func(int A[], int &n) { for (int i = 0; i < n; i++) { cout << A[i] << " "; } } int main() { int A[100], n; input_func(A, n); cout << "mang ban dau la:"; output_func(A, n); InsertSort(A, n); cout << "mang khi sap xep la:"; output_func(A, n); cin.get(); getchar(); return 0; }

Nhập vào số lượng phần tử của mảng và độ dài của mảng để xem kết quả.

Post navigation

Thuật toán sắp xếp nổi bọt (bubble sort)Đổi ngôn ngữ mặc định Netbeans 8.X

Related Posts

Top 5 phần mềm viết code tốt nhất cho lập trình Web

January 3, 2019January 3, 2019Hinata

Bài 12: Câu lệnh rẽ nhánh if, if…else, switch – Điều khiển luồng trong C++

March 17, 2018September 25, 2018NM Dang

Sắp xếp theo cơ số (Radix Sort)

June 9, 2018October 31, 2019NM Dang

New Posts

  • OSError WinError 193 – Invalid Win32 Application

    January 4, 2025Del Margaret
  • Adding Elements to a List While Iterating in Python 3

    January 4, 2025Dimity Margaret
  • Cross-referencing a function generated by autodoc in Sphinx

    January 4, 2025Auberon Lauren
  • Using nose’s assert_raises in Python 3 programming

    January 4, 2025Singh Jessica
  • Difference between type(obj) and obj.__class__

    January 4, 2025Del Margaret

Từ khóa » độ Phức Tạp Của Thuật Toán Sắp Xếp Chèn