- vừa được xem lúc

Hàm sắp xếp trong STL C++

0 0 27

Người đăng: Viblo Algorithm

Theo Viblo Asia

I. Giới thiệu về STL

STL (Standard Template Library) là một thư viện template (lập trình theo mẫu) cho C++ với những cấu trúc dữ liệu cũng như giải thuật được xây dựng tổng quát mà vẫn tận dụng được hiệu năng và tốc độ của ngôn ngữ lập trình C. Với khái niệm template, những người lập trình đã đề ra khái niệm lập trình khái lược (generic programming), C++ được cung cấp kèm với bộ thư viện chuẩn STL.

Để sử dụng STL, bạn cần khai báo từ khóa using namespace std; sau các khai báo thư viện (ví dụ #include).

#include <iostream>
#include <vector> using namespace std; //khai báo sử dụng STL main()
{ ....
}

Tại bài viết này mình sẽ không đi sâu vào các tính năng của thư viện STL mà chú yếu khai thác các đặc tính cũng như cách sử dụng của hàm sort() trong thư viện STL của C++.

II. Một số cách sử dụng hàm sort()

1. Khai báo thư viện

Để sử dụng hàm sort(), chúng ta cần khai báo thư viện algorithm:

#include<algorithm>

2. Truy cập địa chỉ của phần tử trong mảng và vector

Các hàm thao tác trên đoạn trong thư viện <algorithm> đều sử dụng các tham số là các địa chỉ. Mỗi biến được tạo ra trong khi lập trình đều có địa chỉ cụ thể trong bộ nhớ, và các biến địa chỉ sẽ giúp chúng ta truy cập tới địa chỉ của biến đó. Đối với mảng và vector, ta có cách truy cập nhanh tới địa chỉ của các phần tử như sau:

Đối với mảng:

{Tên_mảng} + {Vị_trí};

Đối với vector:

{Tên_vector}.begin() + {Vị_trí};

3. Sắp xếp cơ bản

Xét mảng gồm n phần tử:

a[0],a[1],a[2],a[3],a[4],a[5],a[6],a[7],a[8],a[9]a[0], a[1], a[2], a[3], a[4], a[5], a[6], a[7], a[8], a[9]

Cách dùng cơ bản nhất của hàm sort() là sắp xếp tăng dần các phần tử từ vị trí ii đến vị trí jj (lưu ý ở đây ta xét mảng bắt đầu từ vị trí 00):

sort(a + i, a + j + 1);

Ngoài ra đối với một số kiểu dữ liệu khác, như vector, ta có thể sử dụng câu lệnh như sau:

sort(a.begin(), a.end());

Ví dụ tham khảo:

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std; int main()
{ int a[6] = {5, 4, 3, 2, 1, 0}; sort(a, a + 6); // thu được 0 1 2 3 4 5
//	sort(a + 2, a + 5); thu được 5 4 1 2 3 0 vector<int> a = {5, 4, 3, 2, 1, 0}; sort(a.begin(), a.end()); // thu được 0 1 2 3 4 5 return 0;
}

4. Sắp xếp theo thứ tự giảm dần

Chúng ta có thể sắp xếp các phần tử theo thứ tự giảm dần bằng cách truyền tham số comp vào con trỏ hàm của hàm sort() như sau:

bool comp(const int a, const int b){ return a > b;
}
int main(){ int a[6] = {0, 1, 2, 3, 4, 5}; sort(a, a + 6, comp); // thu được 5 4 3 2 1 0 vector<int> a = {0, 1, 2, 3, 4, 5}; sort(a.begin(), a.end(), comp); // thu được 5 4 3 2 1 0 return 0;
}

5. Sử dụng 2 phép toán less và greater

Hai từ khóa lessgreater thể hiện cho hai phép toán sắp xếp tăng dần hoặc giảm dần (thực ra chính là thể hiện của các toán tử <>), khi muốn điều chỉnh cách sắp xếp ta chỉ cần thêm hai phép toán này vào tham số thứ ba của hàm sắp xếp theo cú pháp:

sort(l, r, greater < {Kiểu_phần_tử} >());
sort(l, r, less < {Kiểu_phần_tử} >());

Trong đó, {Kiểu_phần_tử} là kiểu dữ liệu của các phần tử trong tập hợp cần sắp xếp.

  • Chương trình tham khảo:
#include <bits/stdc++.h>
using namespace std; bool cmp(int A, int B)
{ return A > B;
} int main()
{ int a[] = {5, 2, 10, 3, 1}; // Sắp xếp mảng. sort(a, a + 5, cmp); // a = {10, 5, 3, 2, 1}. // In ra kết quả sắp xếp. cout << "Kết quả sắp xếp: " << endl; for (int i = 0; i < 5; ++i) cout << a[i] << ' '; return 0;
}

Biên dịch và chạy chương trình trên sẽ cho ra kết quả:

Kết quả sắp xếp:
10 5 3 2 1

6. Một vài kiểu sắp xếp khác

  • Sắp xếp theo bảng chữ cái:
int main()
{ string str[5] = {"c", "abc", "ac", "bb", "aaaa"}; sort(str, str + 5); // "aaaa" "abc" "ac" "bb" "c" return 0;
}
  • Sắp xếp theo bảng chữ cái kết hợp độ dài tăng dần:
bool cmp(string str1,string str2)
{ return str1.length() < str2.length();
}
int main()
{ string str[5] = {"c", "abc", "ac", "bb", "aaaa"}; sort(str, str + 5, cmp); // "c" "ac" "bb" "abc" "aaaa" return 0;
}

III. Xung quanh hàm sort()

1. Tham số phụ comp

Đây là một yếu tố ta có thể thay đổi linh hoạt để hướng hàm sort() đến mục đích mong muốn của chúng ta. Ngoài những ví dụ như trên bạn hoàn toàn có thể xây dựng một hàm sort() đặc biệt dành riêng cho bạn.

2. Nhận xét về hàm sort()

Hàm sort() tối ưu hóa hơn các đặc điểm so với những thuật toán sắp xếp thông thường, nó là một sự kết hợp cũng như cải tiến dung hòa giữa các thuật toán sắp xếp. Với tính linh hoạt của nó, hầu như hàm sort() có thể đáp ứng đầy đủ những nhu cầu sắp xếp của chúng ta.

3. Một số hàm sắp xếp khác

Ngoài ra bạn có thể tìm hiểu một số hàm sắp xếp khác, mỗi hàm đều có những điểm đặc biệt riêng của nó:

stable_sort partial_sort partial_sort_copy nth_element is_sorted partition stable_partition

IV. Tài liệu tham khảo

Bình luận

Bài viết tương tự

- vừa được xem lúc

Giới thiệu Typescript - Sự khác nhau giữa Typescript và Javascript

Typescript là gì. TypeScript là một ngôn ngữ giúp cung cấp quy mô lớn hơn so với JavaScript.

0 0 525

- vừa được xem lúc

Cài đặt WSL / WSL2 trên Windows 10 để code như trên Ubuntu

Sau vài ba năm mình chuyển qua code trên Ubuntu thì thật không thể phủ nhận rằng mình đã yêu em nó. Cá nhân mình sử dụng Ubuntu để code web thì thật là tuyệt vời.

0 0 396

- vừa được xem lúc

Đặt tên commit message sao cho "tình nghĩa anh em chắc chắn bền lâu"????

. Lời mở đầu. .

1 1 738

- vừa được xem lúc

Tìm hiểu về Resource Controller trong Laravel

Giới thiệu. Trong laravel, việc sử dụng các route post, get, group để gọi đến 1 action của Controller đã là quá quen đối với các bạn sử dụng framework này.

0 0 358

- vừa được xem lúc

Phân quyền đơn giản với package Laravel permission

Như các bạn đã biết, phân quyền trong một ứng dụng là một phần không thể thiếu trong việc phát triển phần mềm, dù đó là ứng dụng web hay là mobile. Vậy nên, hôm nay mình sẽ giới thiệu một package có thể giúp các bạn phân quyền nhanh và đơn giản trong một website được viết bằng PHP với framework là L

0 0 449

- vừa được xem lúc

Bạn đã biết các tips này khi làm việc với chuỗi trong JavaScript chưa ?

Hi xin chào các bạn, tiếp tục chuỗi chủ đề về cái thằng JavaScript này, hôm nay mình sẽ giới thiệu cho các bạn một số thủ thuật hay ho khi làm việc với chuỗi trong JavaScript có thể bạn đã hoặc chưa từng dùng. Cụ thể như nào thì hãy cùng mình tìm hiểu trong bài viết này nhé (go).

0 0 433