trieu.dev.da
Nguyễn Thanh Triều
Thuật toán là gì?
Ví dụ:
O(1): thường tương ứng với một lệnh bình thường
O: duyệt vòng lặp for
O(n^2): duyệt vòng lặp for lồng vòng lặp for
O(logn): duyệt vòng lặp for và xử lý dữ liệu dạng [].push(item)
O(n!): trường hợp tệ nhất, có độ phức tạp cao. Sử dụng đệ quy không hợp lý sẽ gặp trường hợp này.
- Khi mà giải quyết một bài toán thì thuật toán giúp giải quyết bài toán một cách tốt và hiệu quả nhất.
- Cơ bản thường gặp thuật toán tìm kiếm và sắp xếp
- Thuật toán tìm kiếm một phần tử thỏa mãn điều kiện nào đó trong mảng nhiều phần tử
- Cho một mảng sắp xếp mảng theo thứ tự tăng dần, giảm dần.
Ví dụ:
O(1): thường tương ứng với một lệnh bình thường
O: duyệt vòng lặp for
O(n^2): duyệt vòng lặp for lồng vòng lặp for
O(logn): duyệt vòng lặp for và xử lý dữ liệu dạng [].push(item)
O(n!): trường hợp tệ nhất, có độ phức tạp cao. Sử dụng đệ quy không hợp lý sẽ gặp trường hợp này.
- Theo thứ tự độ phức tạp tăng dần từ O(1) tới O(n!). Độ phức tạp càng thấp thì thuật toán càng tốt.
- Sắp xếp nổi bọt sẽ đổi vị trí các phần tử với nhau. Phần tử nào lớn (nhỏ) hơn sẽ nổi bọt (đổi chỗ). Lặp lại cho đến khi các phần tử đúng thứ tự.
- Độ phức tạp trường hợp xấu nhất: O(n^2). Khá chậm nếu có nhiều dữ liệu.
- Thuật toán Selection Sort sắp xếp một mảng bằng cách liên tục tìm phần tử nhỏ nhất (xét theo thứ tự tăng dần) từ phần chưa được sắp xếp và đặt nó ở đầu. Thuật toán duy trì hai mảng con:
- Mảng con đã được sắp xếp.
- Mảng con còn lại chưa được sắp xếp.
- Thuật toán Selection Sort là một thuật toán khá đơn giản khi cài đặt. Thuật toán này có độ phức tạp là O(n2) vì có 2 vòng lặp.