SlideShare a Scribd company logo
Kỹ thuật lập trình
010101010101010110000101010101010101011000010101010101010101100001
010101010010101010010101010101001010101001010101010100101010100101
101001100011001001001010100110001100100100101010011000110010010010
110010110010001000001011001011001000100000101100101100100010000010
010101010101010110000101010101010101011000010101010101010101100001
010101010010101010010101010101001010101001010101010100101010100101
101001100011001001001010100110001100100100101010011000110010010010
110010110010001000001011001011001000100000101100101100100010000010
010101010101010110000101010101010101011000010101010101010101100001
010101010010101010010101010101001010101001010101010100101010100101
101001100011001001001010100110001100100100101010011000110010010010
110010110010001000001011001011001000100000101100101100100010000010
12/25/2007
y = A*x + B*u;
x = C*x + d*u;
StateController
start()
stop()
LQGController
start()
stop()
Chương 10: Thuật toán tổng quát
2Chương 10: Thuật toán tổng quát
Nội dung chương 10
10.1 Tổng quát hóa kiểu dữ liệu phần tử
10.2 Tổng quát hóa phép toán cơ sở
10.3 Tổng quát hóa phương pháp truy lặp phần tử
3Chương 10: Thuật toán tổng quát
10.1 Tổng quát hóa kiểu dữ liệu phần tử
Thực tế:
— Khoảng 80% thời gian làm việc của một người thư ký văn phòng
trước ₫ây (và hiện nay ở nhiều nơi) sử dụng cho công việc tìm
kiếm, sắp xếp, ₫ối chiếu, so sánh,.... tài liệu và hồ sơ
— Trung bình, khoảng 80% mã chương trình và thời gian thực hiện
chương trình dành cho thực hiện các thuật toán ít liên quan trực
tiếp tới bài toán ứng dụng cụ thể, mà liên quan tới tìm kiếm, sắp
xếp, lựa chọn, so sánh... dữ liệu
Dữ liệu ₫ược quản lý tốt nhất trong các cấu trúc dạng
"container" (vector, list, map, tree, queue,...)
Vấn ₫ề xây dựng hàm áp dụng cho các "container": Nhiều hàm
chỉ khác nhau về kiểu dữ liệu tham số áp dụng, không khác
nhau về thuật toán
Giải pháp: Xây dựng khuôn mẫu hàm, tổng quát hóa kiểu dữ
liệu phần tử
4Chương 10: Thuật toán tổng quát
Ví dụ: Thuật toán tìm ₫ịa chỉ phần tử ₫ầu tiên trong một mảng có giá
trị lớn hơn một số cho trước:
template <typename T>
T* find_elem(T *first, T* last, T k) {
while (first != last && !(*first > k))
++first;
return first;
}
void main() {
int a[] = { 1, 3, 5, 2, 7, 9, 6 };
int *p = find_elem(a,a+7,4);
if (p != a+7) {
cout << "First number > 4 :" << *p;
p = find_elem(p+1,a+7,4);
if (p != a+7) cout << "Second number > 4:" << *p;
}
double b[] = { 1.5, 3.2, 5.1, 2.4, 7.6, 9.7, 6.5 };
double *q = find_elem(b+2,b+6,7.0);
*q = 7.0;
...
}
5Chương 10: Thuật toán tổng quát
Ví dụ: Thuật toán cộng hai vector, kết quả lưu vào vector thứ ba
#include <assert.h>
#include "myvector.h"
template <typename T>
void addVector(const Vector<T>& a, const Vector<T>& b,
Vector<T>& c) {
assert(a.size() == b.size() && a.size() == c.size());
for (int i= 0; i < a.size(); ++i)
c[i] = a[i] + b[i];
}
template <typename T>
Vector<T> operator+(const Vector<T>&a, const Vector<T>& b) {
Vector<T> c(a.size());
addVector(a,b,c);
return c;
}
6Chương 10: Thuật toán tổng quát
10.2 Tổng quát hóa phép toán cơ sở
Vấn ₫ề: Nhiều thuật toán chỉ khác nhau ở một vài phép toán
(cơ sở) trong khi thực hiện hàm
Ví dụ:
— Các thuật toán tìm ₫ịa chỉ phần tử ₫ầu tiên trong một mảng số
nguyên có giá trị lớn hơn, nhỏ hơn, lớn hơn hoặc bằng, nhỏ hơn
hoặc bằng, ... một số cho trước
— Các thuật toán cộng, trừ, nhân, chia,... từng phần tử của hai mảng
số thực, kết quả lưu vào một mảng mới
— Các thuật toán cộng, trừ, nhân, chia,... từng phần tử của hai
vector (hoặc của hai danh sách, hai ma trận, ...)
Giải pháp: Tổng quát hóa thuật toán cho các phép toán cơ sở
khác nhau!
7Chương 10: Thuật toán tổng quát
template <typename COMP>
int* find_elem(int* first, int* last, int k, COMP comp) {
while (first != last && !comp(*first, k))
++first;
return first;
}
bool is_greater(int a, int b) { return a > b; }
bool is_less(int a, int b) { return a < b; }
bool is_equal(int a, int b) { return a == b;}
void main() {
int a[] = { 1, 3, 5, 2, 7, 9, 6 };
int* alast = a+7;
int* p1 = find_elem(a,alast,4,is_greater);
int* p2 = find_elem(a,alast,4,is_less);
int* p3 = find_elem(a,alast,4,is_equal);
if (p1 != alast) cout << "First number > 4 is " << *p1;
if (p2 != alast) cout << "First number < 4 is " << *p2;
if (p3 != alast) cout << "First number = 4 is at index "
<< p3 - a;
char c; cin >> c;
}
8Chương 10: Thuật toán tổng quát
Tham số khuôn mẫu cho phép toán
Có thể là một hàm, ví dụ
bool is_greater(int a, int b){ return a > b; }
bool is_less(int a, int b) { return a < b; }
int add(int a, int b) { return a + b; }
int sub(int a, int b) { return a - b; }
...
Hoặc tốt hơn hết là một ₫ối tượng thuộc một lớp có hỗ trợ (nạp
chồng) toán tử gọi hàm => ₫ối tượng hàm, ví dụ
struct Greater {
bool operator()(int a, int b) { return a > b; }
};
struct Less {
bool operator()(int a, int b) { return a < b; }
};
struct Add {
int operator()(int a, int b) { return a + b; }
};
...
9Chương 10: Thuật toán tổng quát
Ví dụ sử dụng ₫ối tượng hàm
void main() {
int a[] = { 1, 3, 5, 2, 7, 9, 6 };
int* alast = a+7;
Greater greater;
Less less;
int* p1 = find_elem(a,alast,4,greater);
int* p2 = find_elem(a,alast,4,less);
if (p1 != alast) cout << "First number > 4 is " << *p1;
if (p2 != alast) cout << "First number < 4 is " << *p2;
p1 = find_elem(a,alast,4,Greater());
p2 = find_elem(a,alast,4,Less());
char c; cin >> c;
}
10Chương 10: Thuật toán tổng quát
Ưu ₫iểm của ₫ối tượng hàm
Đối tượng hàm có thể chứa trạng thái
Hàm toán tử () có thể ₫ịnh nghĩa inline => tăng hiệu suất
template <typename OP>
void apply(int* first, int* last, OP& op) {
while (first != last) {
op(*first);
++first;
}
}
class Sum {
int val;
public:
Sum(int init = 0) : val(init) {}
void operator()(int k) { val += k; }
int value() const { return val; }
};
11Chương 10: Thuật toán tổng quát
class Prod {
int val;
public:
Prod(int init=1): val(init) {}
void operator()(int k) { val *= k; }
int value() const { return val; }
};
struct Negate {void operator()(int& k) { k = -k;} };
struct Print { void operator()(int& k) { cout << k << ' ';} };
void main() {
int a[] = {1, 2, 3, 4, 5, 6, 7};
Sum sum_op;
Prod prod_op;
apply(a,a+7,sum_op); cout << sum_op.value() << endl;
apply(a,a+7,prod_op); cout << prod_op.value() << endl;
apply(a,a+7,Negate());
apply(a,a+7,Print());
char c; cin >> c;
}
12Chương 10: Thuật toán tổng quát
Kết hợp 2 bước tổng quát hóa
template <typename T, typename COMP>
T* find_elem(T* first, T* last, T k, COMP comp) {
while (first != last && !comp(*first, k))
++first;
return first;
}
template <typename T, typename OP>
void apply(T* first, T* last, OP& op) {
while (first != last) {
op(*first);
++first;
}
}
13Chương 10: Thuật toán tổng quát
Khuôn mẫu lớp cho các ₫ối tượng hàm
template <typename T> struct Greater{
bool operator()(const T& a, const T& b)
{ return a > b; }
};
template <typename T> struct Less{
bool operator()(const T& a, const T& b)
{ return a > b; }
};
template <typename T> class Sum {
T val;
public:
Sum(const T& init = T(0)) : val(init) {}
void operator()(const T& k) { val += k; }
T value() const { return val; }
};
14Chương 10: Thuật toán tổng quát
template <typename T> struct Negate {
void operator()(T& k) { k = -k;}
};
template <typename T> struct Print {
void operator()(const T& k) { cout << k << ' ';}
};
void main() {
int a[] = { 1, 3, 5, 2, 7, 9, 6 };
int* alast = a+7;
int* p1 = find_elem(a,alast,4,Greater<int>());
int* p2 = find_elem(a,alast,4,Less<int>());
if (p1 != alast) cout << "nFirst number > 4 is " << *p1;
if (p2 != alast) cout << "nFirst number < 4 is " << *p2;
Sum<int> sum_op; apply(a,a+7,sum_op);
cout<< "nSum of the sequence " << sum_op.value() << endl;
apply(a,a+7,Negate<int>());
apply(a,a+7,Print<int>());
char c; cin >> c;
}
15Chương 10: Thuật toán tổng quát
10.3 Tổng quát hóa truy lặp phần tử
Vấn ₫ề 1: Một thuật toán (tìm kiếm, lựa chọn, phân loại, tính
tổng, ...) áp dụng cho một mảng, một vector, một danh sách
họăc một cấu trúc khác thực chất chỉ khác nhau ở cách truy
lặp phần tử
Vấn ₫ề 2: Theo phương pháp truyền thống, ₫ể truy lặp phần tử
của một cấu trúc "container", nói chung ta cần biết cấu trúc ₫ó
₫ược xây dựng như thế nào
— Mảng: Truy lặp qua chỉ số hoặc qua con trỏ
— Vector: Truy lặp qua chỉ số
— List: Truy lặp qua quan hệ móc nối (sử dụng con trỏ)
— ...
16Chương 10: Thuật toán tổng quát
Ví dụ thuật toán copy
Áp dụng cho kiểu mảng thô
template <class T> void copy(const T* s, T* d, int n) {
while (n--) { *d = *s; ++s; ++d; }
}
Áp dụng cho kiểu Vector
template <class T>
void copy(const Vector<T>& s, Vector<T>& d) {
for (int i=0; i < s.size(); ++i) d[i] = s[i];
}
Áp dụng cho kiểu List
template <class T>
void copy(const List<T>& s, List<T>& d) {
ListItem<T> *sItem=s.getHead(), *dItem=d.getHead();
while (sItem != 0) {
dItem->data = sItem->data;
dIem = dItem->getNext(); sItem=sItem->getNext();
}
}
17Chương 10: Thuật toán tổng quát
Ví dụ thuật toán find_max
Áp dụng cho kiểu mảng thô
template <typename T> T* find_max(T* first, T* last) {
T* pMax = first;
while (first != last) {
if (*first > *pMax) pMax = first;
++first;
}
return pMax;
}
Áp dụng cho kiểu Vector
template <typename T> T* find_max(const Vector<T>& v) {
int iMax = 0;
for (int i=0; i < v.size(); ++ i)
if (v[i] > v[iMax]) iMax = i;
return &v[iMax];
}
18Chương 10: Thuật toán tổng quát
Áp dụng cho kiểu List (₫ã làm quen):
template <typename T>
ListItem<T>* find_max(List<T>& l) {
ListItem<T> *pItem = l.getHead();
ListItem<T> *pMaxItem = pItem;
while (pItem != 0) {
if (pItem->data > pMaxItem->data) pMaxItem = pItem;
pItem = pItem->getNext();
}
return pMaxItem;
}
Cần tổng quát hóa phương pháp truy lặp phần tử!
19Chương 10: Thuật toán tổng quát
Bộ truy lặp (iterator)
Mục ₫ích: Tạo một cơ chế thống nhất cho việc truy lặp phần tử
cho các cấu trúc dữ liệu mà không cần biết chi tiết thực thi bên
trong từng cấu trúc
Ý tưởng: Mỗi cấu trúc dữ liệu cung cấp một kiểu bộ truy lặp
riêng, có ₫ặc tính tương tự như một con trỏ (trong trường
hợp ₫ặc biệt có thể là một con trỏ thực)
Tổng quát hóa thuật toán copy:
template <class Iterator1, class Iterator2>
void copy(Iterator1 s, Iterator2 d, int n) {
while (n--) {
*d = *s;
++s;
++d;
}
}
Các phép toán áp dụng
₫ược tương tự con trỏ
20Chương 10: Thuật toán tổng quát
Tổng quát hóa thuật toán find_max:
template <typename ITERATOR>
ITERATOR find_max(ITERATOR first, ITERATOR last) {
ITERATOR pMax = first;
while (first != last) {
if (*first > *pMax) pMax = first;
++first;
}
return pMax;
}
Các phép toán áp dụng
₫ược tương tự con trỏ
21Chương 10: Thuật toán tổng quát
Bổ sung bộ truy lặp cho kiểu Vector
Kiểu Vector lưu trữ dữ liệu dưới dạng một mảng => có thể sử
dụng bộ truy lặp dưới dạng con trỏ!
template <class T> class Vector {
int nelem;
T* data;
public:
...
typedef T* Iterator;
Iteratator begin() { return data; }
Iteratator end() { return data + nElem; }
};
void main() {
Vector<double> a(5,1.0),b(6);
copy(a.begin(),b.begin(),a.size());
...
}
22Chương 10: Thuật toán tổng quát
Bổ sung bộ truy lặp cho kiểu List
template <class T> class ListIterator {
ListItem<T> *pItem;
ListIterator(ListItem<T>* p = 0) : pItem(p) {}
friend class List<T>;
public:
T& operator*() { return pItem->data; }
ListIterator<T>& operator++() {
if (pItem != 0) pItem = pItem->getNext();
return *this;
}
friend bool operator!=(ListIterator<T> a,
ListIterator<T> b) {
return a.pItem != b.pItem;
}
};
23Chương 10: Thuật toán tổng quát
Khuôn mẫu List cải tiến
template <class T> class List {
ListItem<T> *pHead;
public:
...
ListIterator<T> begin() {
return ListIterator<T>(pHead);
}
ListIterator<T> end() {
return ListIterator<T>(0);
}
};
24Chương 10: Thuật toán tổng quát
Bài tập về nhà
Xây dựng thuật toán sắp xếp tổng quát ₫ể có thể áp dụng cho
nhiều cấu trúc dữ liệu tập hợp khác nhau cũng như nhiều tiêu
chuẩn sắp xếp khác nhau. Viết chương trình minh họa.
Xây dựng thuật toán cộng/trừ/nhân/chia từng phần tử của hai
cấu trúc dữ liệu tập hợp bất kỳ. Viết chương trình minh họa.

More Related Content

What's hot

Lập trình c++ có lời giải 2
Lập trình c++ có lời giải 2Lập trình c++ có lời giải 2
Lập trình c++ có lời giải 2Minh Ngoc Tran
 
Local sakainame 501127 ktl_trình hlmt1 a01 fall 2013 _ modules
Local sakainame   501127 ktl_trình hlmt1 a01 fall 2013 _ modulesLocal sakainame   501127 ktl_trình hlmt1 a01 fall 2013 _ modules
Local sakainame 501127 ktl_trình hlmt1 a01 fall 2013 _ modulesTrần Văn Nam
 
Hướng dẫn làm bt về chuỗi.doc
Hướng dẫn làm bt về chuỗi.docHướng dẫn làm bt về chuỗi.doc
Hướng dẫn làm bt về chuỗi.docTrần Văn Nam
 
đáP án 24 đề tin
đáP án 24 đề tinđáP án 24 đề tin
đáP án 24 đề tinTtx Love
 
giao trinh c++ Chuong1
giao trinh c++ Chuong1giao trinh c++ Chuong1
giao trinh c++ Chuong1Bễ Nguyễn
 
C đến C++ phần 1
C đến C++ phần 1C đến C++ phần 1
C đến C++ phần 1
TechMaster Vietnam
 
Một số vấn đề thường gặp trong lập trình - Đăng Bình Phương (ĐH KHTN)
Một số vấn đề thường gặp trong lập trình - Đăng Bình Phương (ĐH KHTN)Một số vấn đề thường gặp trong lập trình - Đăng Bình Phương (ĐH KHTN)
Một số vấn đề thường gặp trong lập trình - Đăng Bình Phương (ĐH KHTN)Thanh Minh Hoang
 
Lap trinh huong_doi_tuong_cpp_dhct_lesson08
Lap trinh huong_doi_tuong_cpp_dhct_lesson08Lap trinh huong_doi_tuong_cpp_dhct_lesson08
Lap trinh huong_doi_tuong_cpp_dhct_lesson08xcode_esvn
 
Giao trinh bai tap c va c++
Giao trinh bai tap c va c++Giao trinh bai tap c va c++
Giao trinh bai tap c va c++Congdat Le
 
Neural Network from Scratch
Neural Network from ScratchNeural Network from Scratch
Neural Network from Scratch
TechMaster Vietnam
 
Bai tap lam quen java
Bai tap lam quen javaBai tap lam quen java
Bai tap lam quen javaTuấn Bùi
 

What's hot (17)

Tut6 solution
Tut6 solutionTut6 solution
Tut6 solution
 
Lập trình c++ có lời giải 2
Lập trình c++ có lời giải 2Lập trình c++ có lời giải 2
Lập trình c++ có lời giải 2
 
Local sakainame 501127 ktl_trình hlmt1 a01 fall 2013 _ modules
Local sakainame   501127 ktl_trình hlmt1 a01 fall 2013 _ modulesLocal sakainame   501127 ktl_trình hlmt1 a01 fall 2013 _ modules
Local sakainame 501127 ktl_trình hlmt1 a01 fall 2013 _ modules
 
Bai de quy
Bai de quyBai de quy
Bai de quy
 
Bai tap oop c++
Bai tap oop c++Bai tap oop c++
Bai tap oop c++
 
Hướng dẫn làm bt về chuỗi.doc
Hướng dẫn làm bt về chuỗi.docHướng dẫn làm bt về chuỗi.doc
Hướng dẫn làm bt về chuỗi.doc
 
Lab4
Lab4Lab4
Lab4
 
đáP án 24 đề tin
đáP án 24 đề tinđáP án 24 đề tin
đáP án 24 đề tin
 
Tut6
Tut6Tut6
Tut6
 
giao trinh c++ Chuong1
giao trinh c++ Chuong1giao trinh c++ Chuong1
giao trinh c++ Chuong1
 
C đến C++ phần 1
C đến C++ phần 1C đến C++ phần 1
C đến C++ phần 1
 
Lesson08
Lesson08Lesson08
Lesson08
 
Một số vấn đề thường gặp trong lập trình - Đăng Bình Phương (ĐH KHTN)
Một số vấn đề thường gặp trong lập trình - Đăng Bình Phương (ĐH KHTN)Một số vấn đề thường gặp trong lập trình - Đăng Bình Phương (ĐH KHTN)
Một số vấn đề thường gặp trong lập trình - Đăng Bình Phương (ĐH KHTN)
 
Lap trinh huong_doi_tuong_cpp_dhct_lesson08
Lap trinh huong_doi_tuong_cpp_dhct_lesson08Lap trinh huong_doi_tuong_cpp_dhct_lesson08
Lap trinh huong_doi_tuong_cpp_dhct_lesson08
 
Giao trinh bai tap c va c++
Giao trinh bai tap c va c++Giao trinh bai tap c va c++
Giao trinh bai tap c va c++
 
Neural Network from Scratch
Neural Network from ScratchNeural Network from Scratch
Neural Network from Scratch
 
Bai tap lam quen java
Bai tap lam quen javaBai tap lam quen java
Bai tap lam quen java
 

Similar to C10 generic algorithms

Chapter04_Array_chinhsua
Chapter04_Array_chinhsuaChapter04_Array_chinhsua
Chapter04_Array_chinhsua
ThnhNguynHong5
 
Cpl test1%20key
Cpl test1%20keyCpl test1%20key
Cpl test1%20keyHồ Lợi
 
Bài tập ôn lập trình
Bài tập ôn lập trìnhBài tập ôn lập trình
Bài tập ôn lập trình
Thai Hoc Vu
 
Data Structures and Algorithms Gụidance
Data Structures and Algorithms GụidanceData Structures and Algorithms Gụidance
Data Structures and Algorithms Gụidance
Popping Khiem - Funky Dance Crew PTIT
 
Bài tập mẫu C và C++ có giải
Bài tập mẫu C và C++ có giảiBài tập mẫu C và C++ có giải
Bài tập mẫu C và C++ có giải
Trung Thanh Nguyen
 
C8 object-oriented thinking
C8 object-oriented thinkingC8 object-oriented thinking
C8 object-oriented thinking
Tiến Quang Phan
 
C8 object-oriented thinking
C8 object-oriented thinkingC8 object-oriented thinking
C8 object-oriented thinkingHồ Lợi
 
Lap trinh huong_doi_tuong_cpp_dhct_lesson07
Lap trinh huong_doi_tuong_cpp_dhct_lesson07Lap trinh huong_doi_tuong_cpp_dhct_lesson07
Lap trinh huong_doi_tuong_cpp_dhct_lesson07xcode_esvn
 
Session 4
Session 4Session 4
Session 4
pnanhvn
 
Stl vector nguyen_trihai_11520094_khmt06
Stl vector nguyen_trihai_11520094_khmt06Stl vector nguyen_trihai_11520094_khmt06
Stl vector nguyen_trihai_11520094_khmt06
Quach Long
 
4 Pointer String Struct
4 Pointer String  Struct4 Pointer String  Struct
4 Pointer String StructCuong
 
C9 templates
C9 templatesC9 templates
C9 templates
Tiến Quang Phan
 
Tu-Hoc-Python-Co-Ban-Trong-10-Phut-NIIT
Tu-Hoc-Python-Co-Ban-Trong-10-Phut-NIITTu-Hoc-Python-Co-Ban-Trong-10-Phut-NIIT
Tu-Hoc-Python-Co-Ban-Trong-10-Phut-NIIT
NIIT - ICT Hà Nội
 

Similar to C10 generic algorithms (20)

Lesson08
Lesson08Lesson08
Lesson08
 
Chapter04_Array_chinhsua
Chapter04_Array_chinhsuaChapter04_Array_chinhsua
Chapter04_Array_chinhsua
 
Cpl test1%20key
Cpl test1%20keyCpl test1%20key
Cpl test1%20key
 
Chuong1 c
Chuong1 c Chuong1 c
Chuong1 c
 
Bài tập ôn lập trình
Bài tập ôn lập trìnhBài tập ôn lập trình
Bài tập ôn lập trình
 
Data Structures and Algorithms Gụidance
Data Structures and Algorithms GụidanceData Structures and Algorithms Gụidance
Data Structures and Algorithms Gụidance
 
Bài tập mẫu C và C++ có giải
Bài tập mẫu C và C++ có giảiBài tập mẫu C và C++ có giải
Bài tập mẫu C và C++ có giải
 
344444
344444344444
344444
 
Ctdl lab01
Ctdl lab01Ctdl lab01
Ctdl lab01
 
C8 object-oriented thinking
C8 object-oriented thinkingC8 object-oriented thinking
C8 object-oriented thinking
 
C8 object-oriented thinking
C8 object-oriented thinkingC8 object-oriented thinking
C8 object-oriented thinking
 
Lap trinh huong_doi_tuong_cpp_dhct_lesson07
Lap trinh huong_doi_tuong_cpp_dhct_lesson07Lap trinh huong_doi_tuong_cpp_dhct_lesson07
Lap trinh huong_doi_tuong_cpp_dhct_lesson07
 
Session 4
Session 4Session 4
Session 4
 
Giao trinh bai tap c va c++
Giao trinh bai tap c va c++Giao trinh bai tap c va c++
Giao trinh bai tap c va c++
 
Stl vector nguyen_trihai_11520094_khmt06
Stl vector nguyen_trihai_11520094_khmt06Stl vector nguyen_trihai_11520094_khmt06
Stl vector nguyen_trihai_11520094_khmt06
 
Lesson07
Lesson07Lesson07
Lesson07
 
4 Pointer String Struct
4 Pointer String  Struct4 Pointer String  Struct
4 Pointer String Struct
 
C9 templates
C9 templatesC9 templates
C9 templates
 
C9 templates
C9 templatesC9 templates
C9 templates
 
Tu-Hoc-Python-Co-Ban-Trong-10-Phut-NIIT
Tu-Hoc-Python-Co-Ban-Trong-10-Phut-NIITTu-Hoc-Python-Co-Ban-Trong-10-Phut-NIIT
Tu-Hoc-Python-Co-Ban-Trong-10-Phut-NIIT
 

More from Tiến Quang Phan

Windows comunication foundation
Windows comunication foundationWindows comunication foundation
Windows comunication foundation
Tiến Quang Phan
 
VBA for AutoCAD
VBA for AutoCADVBA for AutoCAD
VBA for AutoCAD
Tiến Quang Phan
 
Mainboard
MainboardMainboard
Keyboard shortcuts for windows 8 pdf
Keyboard shortcuts for windows 8 pdfKeyboard shortcuts for windows 8 pdf
Keyboard shortcuts for windows 8 pdf
Tiến Quang Phan
 
Ngon ngu lap trinh c&c++
Ngon ngu lap trinh c&c++Ngon ngu lap trinh c&c++
Ngon ngu lap trinh c&c++
Tiến Quang Phan
 
Nang cao c++
Nang cao c++Nang cao c++
Nang cao c++
Tiến Quang Phan
 
Giao trinh c can ban
Giao trinh c can banGiao trinh c can ban
Giao trinh c can ban
Tiến Quang Phan
 

More from Tiến Quang Phan (15)

Windows comunication foundation
Windows comunication foundationWindows comunication foundation
Windows comunication foundation
 
VBA for AutoCAD
VBA for AutoCADVBA for AutoCAD
VBA for AutoCAD
 
Mainboard
MainboardMainboard
Mainboard
 
Keyboard shortcuts for windows 8 pdf
Keyboard shortcuts for windows 8 pdfKeyboard shortcuts for windows 8 pdf
Keyboard shortcuts for windows 8 pdf
 
C7 class relationship
C7 class relationshipC7 class relationship
C7 class relationship
 
C5 classes and objects
C5 classes and objectsC5 classes and objects
C5 classes and objects
 
C4 data structures
C4 data structuresC4 data structures
C4 data structures
 
C3 functions and_library
C3 functions and_libraryC3 functions and_library
C3 functions and_library
 
C2 basics of_c_and_cpp
C2 basics of_c_and_cppC2 basics of_c_and_cpp
C2 basics of_c_and_cpp
 
C1 introduction
C1 introductionC1 introduction
C1 introduction
 
Ngon ngu lap trinh c&c++
Ngon ngu lap trinh c&c++Ngon ngu lap trinh c&c++
Ngon ngu lap trinh c&c++
 
Nang cao c++
Nang cao c++Nang cao c++
Nang cao c++
 
Giao trinh c can ban
Giao trinh c can banGiao trinh c can ban
Giao trinh c can ban
 
Con tro ham c++
Con tro ham c++Con tro ham c++
Con tro ham c++
 
Thu vien chuan c++
Thu vien chuan c++Thu vien chuan c++
Thu vien chuan c++
 

Recently uploaded

THONG BAO nop ho so xet tuyen TS6 24-25.pdf
THONG BAO nop ho so xet tuyen TS6 24-25.pdfTHONG BAO nop ho so xet tuyen TS6 24-25.pdf
THONG BAO nop ho so xet tuyen TS6 24-25.pdf
QucHHunhnh
 
SLIDE BÀI GIẢNG MÔN THƯƠNG MẠI ĐIỆN TỬ.pdf
SLIDE BÀI GIẢNG MÔN THƯƠNG MẠI ĐIỆN TỬ.pdfSLIDE BÀI GIẢNG MÔN THƯƠNG MẠI ĐIỆN TỬ.pdf
SLIDE BÀI GIẢNG MÔN THƯƠNG MẠI ĐIỆN TỬ.pdf
UyenDang34
 
insulin cho benh nhan nam vien co tang duong huyet
insulin cho benh nhan nam vien co tang duong huyetinsulin cho benh nhan nam vien co tang duong huyet
insulin cho benh nhan nam vien co tang duong huyet
lmhong80
 
BÀI TẬP BỔ TRỢ TIẾNG ANH I-LEARN SMART WORLD 9 CẢ NĂM CÓ TEST THEO UNIT NĂM H...
BÀI TẬP BỔ TRỢ TIẾNG ANH I-LEARN SMART WORLD 9 CẢ NĂM CÓ TEST THEO UNIT NĂM H...BÀI TẬP BỔ TRỢ TIẾNG ANH I-LEARN SMART WORLD 9 CẢ NĂM CÓ TEST THEO UNIT NĂM H...
BÀI TẬP BỔ TRỢ TIẾNG ANH I-LEARN SMART WORLD 9 CẢ NĂM CÓ TEST THEO UNIT NĂM H...
Nguyen Thanh Tu Collection
 
trắc nhiệm ký sinh.docxddddddddddddddddd
trắc nhiệm ký sinh.docxdddddddddddddddddtrắc nhiệm ký sinh.docxddddddddddddddddd
trắc nhiệm ký sinh.docxddddddddddddddddd
my21xn0084
 
40 câu hỏi - đáp Bộ luật dân sự năm 2015 (1).doc
40 câu hỏi - đáp Bộ  luật dân sự năm  2015 (1).doc40 câu hỏi - đáp Bộ  luật dân sự năm  2015 (1).doc
40 câu hỏi - đáp Bộ luật dân sự năm 2015 (1).doc
NguynDimQunh33
 
Halloween vocabulary for kids in primary school
Halloween vocabulary for kids in primary schoolHalloween vocabulary for kids in primary school
Halloween vocabulary for kids in primary school
AnhPhm265031
 
CHUYÊN ĐỀ DẠY THÊM HÓA HỌC LỚP 10 - SÁCH MỚI - FORM BÀI TẬP 2025 (DÙNG CHUNG ...
CHUYÊN ĐỀ DẠY THÊM HÓA HỌC LỚP 10 - SÁCH MỚI - FORM BÀI TẬP 2025 (DÙNG CHUNG ...CHUYÊN ĐỀ DẠY THÊM HÓA HỌC LỚP 10 - SÁCH MỚI - FORM BÀI TẬP 2025 (DÙNG CHUNG ...
CHUYÊN ĐỀ DẠY THÊM HÓA HỌC LỚP 10 - SÁCH MỚI - FORM BÀI TẬP 2025 (DÙNG CHUNG ...
Nguyen Thanh Tu Collection
 
BÁO CÁO CUỐI KỲ PHÂN TÍCH THIẾT KẾ HƯỚNG ĐỐI TƯỢNG - NHÓM 7.docx
BÁO CÁO CUỐI KỲ PHÂN TÍCH THIẾT KẾ HƯỚNG ĐỐI TƯỢNG - NHÓM 7.docxBÁO CÁO CUỐI KỲ PHÂN TÍCH THIẾT KẾ HƯỚNG ĐỐI TƯỢNG - NHÓM 7.docx
BÁO CÁO CUỐI KỲ PHÂN TÍCH THIẾT KẾ HƯỚNG ĐỐI TƯỢNG - NHÓM 7.docx
HngL891608
 
FSSC 22000 version 6_Seminar_FINAL end.pptx
FSSC 22000 version 6_Seminar_FINAL end.pptxFSSC 22000 version 6_Seminar_FINAL end.pptx
FSSC 22000 version 6_Seminar_FINAL end.pptx
deviv80273
 
Biểu tượng trăng và bầu trời trong tác phẩm của Nguyễn Quang Thiều
Biểu tượng trăng và bầu trời trong tác phẩm của Nguyễn Quang ThiềuBiểu tượng trăng và bầu trời trong tác phẩm của Nguyễn Quang Thiều
Biểu tượng trăng và bầu trời trong tác phẩm của Nguyễn Quang Thiều
lamluanvan.net Viết thuê luận văn
 
Smartbiz_He thong MES nganh may mac_2024june
Smartbiz_He thong MES nganh may mac_2024juneSmartbiz_He thong MES nganh may mac_2024june
Smartbiz_He thong MES nganh may mac_2024june
SmartBiz
 
100 DẪN CHỨNG NGHỊ LUẬN XÃ HỘiI HAY.docx
100 DẪN CHỨNG NGHỊ LUẬN XÃ HỘiI HAY.docx100 DẪN CHỨNG NGHỊ LUẬN XÃ HỘiI HAY.docx
100 DẪN CHỨNG NGHỊ LUẬN XÃ HỘiI HAY.docx
khanhthy3000
 
LỊCH SỬ 12 - CHUYÊN ĐỀ 10 - TRẮC NGHIỆM.pptx
LỊCH SỬ 12 - CHUYÊN ĐỀ 10 - TRẮC NGHIỆM.pptxLỊCH SỬ 12 - CHUYÊN ĐỀ 10 - TRẮC NGHIỆM.pptx
LỊCH SỬ 12 - CHUYÊN ĐỀ 10 - TRẮC NGHIỆM.pptx
12D241NguynPhmMaiTra
 
Giải phẫu tim sau đại học- LÊ QUANG TUYỀN
Giải phẫu tim sau đại học- LÊ QUANG TUYỀNGiải phẫu tim sau đại học- LÊ QUANG TUYỀN
Giải phẫu tim sau đại học- LÊ QUANG TUYỀN
linh miu
 
PLĐC-chương 1 (1).ppt của trường ĐH Ngoại thương
PLĐC-chương 1 (1).ppt của trường  ĐH Ngoại thươngPLĐC-chương 1 (1).ppt của trường  ĐH Ngoại thương
PLĐC-chương 1 (1).ppt của trường ĐH Ngoại thương
hieutrinhvan27052005
 
Văn 7. Truyện ngụ ngôn Rùa và thỏ+ Viết PT nhân vật.docx
Văn 7. Truyện ngụ ngôn Rùa và thỏ+ Viết PT nhân vật.docxVăn 7. Truyện ngụ ngôn Rùa và thỏ+ Viết PT nhân vật.docx
Văn 7. Truyện ngụ ngôn Rùa và thỏ+ Viết PT nhân vật.docx
metamngoc123
 
Cau-Trắc-Nghiệm-TTHCM-Tham-Khảo-THI-CUỐI-KI.pdf
Cau-Trắc-Nghiệm-TTHCM-Tham-Khảo-THI-CUỐI-KI.pdfCau-Trắc-Nghiệm-TTHCM-Tham-Khảo-THI-CUỐI-KI.pdf
Cau-Trắc-Nghiệm-TTHCM-Tham-Khảo-THI-CUỐI-KI.pdf
HngMLTh
 

Recently uploaded (18)

THONG BAO nop ho so xet tuyen TS6 24-25.pdf
THONG BAO nop ho so xet tuyen TS6 24-25.pdfTHONG BAO nop ho so xet tuyen TS6 24-25.pdf
THONG BAO nop ho so xet tuyen TS6 24-25.pdf
 
SLIDE BÀI GIẢNG MÔN THƯƠNG MẠI ĐIỆN TỬ.pdf
SLIDE BÀI GIẢNG MÔN THƯƠNG MẠI ĐIỆN TỬ.pdfSLIDE BÀI GIẢNG MÔN THƯƠNG MẠI ĐIỆN TỬ.pdf
SLIDE BÀI GIẢNG MÔN THƯƠNG MẠI ĐIỆN TỬ.pdf
 
insulin cho benh nhan nam vien co tang duong huyet
insulin cho benh nhan nam vien co tang duong huyetinsulin cho benh nhan nam vien co tang duong huyet
insulin cho benh nhan nam vien co tang duong huyet
 
BÀI TẬP BỔ TRỢ TIẾNG ANH I-LEARN SMART WORLD 9 CẢ NĂM CÓ TEST THEO UNIT NĂM H...
BÀI TẬP BỔ TRỢ TIẾNG ANH I-LEARN SMART WORLD 9 CẢ NĂM CÓ TEST THEO UNIT NĂM H...BÀI TẬP BỔ TRỢ TIẾNG ANH I-LEARN SMART WORLD 9 CẢ NĂM CÓ TEST THEO UNIT NĂM H...
BÀI TẬP BỔ TRỢ TIẾNG ANH I-LEARN SMART WORLD 9 CẢ NĂM CÓ TEST THEO UNIT NĂM H...
 
trắc nhiệm ký sinh.docxddddddddddddddddd
trắc nhiệm ký sinh.docxdddddddddddddddddtrắc nhiệm ký sinh.docxddddddddddddddddd
trắc nhiệm ký sinh.docxddddddddddddddddd
 
40 câu hỏi - đáp Bộ luật dân sự năm 2015 (1).doc
40 câu hỏi - đáp Bộ  luật dân sự năm  2015 (1).doc40 câu hỏi - đáp Bộ  luật dân sự năm  2015 (1).doc
40 câu hỏi - đáp Bộ luật dân sự năm 2015 (1).doc
 
Halloween vocabulary for kids in primary school
Halloween vocabulary for kids in primary schoolHalloween vocabulary for kids in primary school
Halloween vocabulary for kids in primary school
 
CHUYÊN ĐỀ DẠY THÊM HÓA HỌC LỚP 10 - SÁCH MỚI - FORM BÀI TẬP 2025 (DÙNG CHUNG ...
CHUYÊN ĐỀ DẠY THÊM HÓA HỌC LỚP 10 - SÁCH MỚI - FORM BÀI TẬP 2025 (DÙNG CHUNG ...CHUYÊN ĐỀ DẠY THÊM HÓA HỌC LỚP 10 - SÁCH MỚI - FORM BÀI TẬP 2025 (DÙNG CHUNG ...
CHUYÊN ĐỀ DẠY THÊM HÓA HỌC LỚP 10 - SÁCH MỚI - FORM BÀI TẬP 2025 (DÙNG CHUNG ...
 
BÁO CÁO CUỐI KỲ PHÂN TÍCH THIẾT KẾ HƯỚNG ĐỐI TƯỢNG - NHÓM 7.docx
BÁO CÁO CUỐI KỲ PHÂN TÍCH THIẾT KẾ HƯỚNG ĐỐI TƯỢNG - NHÓM 7.docxBÁO CÁO CUỐI KỲ PHÂN TÍCH THIẾT KẾ HƯỚNG ĐỐI TƯỢNG - NHÓM 7.docx
BÁO CÁO CUỐI KỲ PHÂN TÍCH THIẾT KẾ HƯỚNG ĐỐI TƯỢNG - NHÓM 7.docx
 
FSSC 22000 version 6_Seminar_FINAL end.pptx
FSSC 22000 version 6_Seminar_FINAL end.pptxFSSC 22000 version 6_Seminar_FINAL end.pptx
FSSC 22000 version 6_Seminar_FINAL end.pptx
 
Biểu tượng trăng và bầu trời trong tác phẩm của Nguyễn Quang Thiều
Biểu tượng trăng và bầu trời trong tác phẩm của Nguyễn Quang ThiềuBiểu tượng trăng và bầu trời trong tác phẩm của Nguyễn Quang Thiều
Biểu tượng trăng và bầu trời trong tác phẩm của Nguyễn Quang Thiều
 
Smartbiz_He thong MES nganh may mac_2024june
Smartbiz_He thong MES nganh may mac_2024juneSmartbiz_He thong MES nganh may mac_2024june
Smartbiz_He thong MES nganh may mac_2024june
 
100 DẪN CHỨNG NGHỊ LUẬN XÃ HỘiI HAY.docx
100 DẪN CHỨNG NGHỊ LUẬN XÃ HỘiI HAY.docx100 DẪN CHỨNG NGHỊ LUẬN XÃ HỘiI HAY.docx
100 DẪN CHỨNG NGHỊ LUẬN XÃ HỘiI HAY.docx
 
LỊCH SỬ 12 - CHUYÊN ĐỀ 10 - TRẮC NGHIỆM.pptx
LỊCH SỬ 12 - CHUYÊN ĐỀ 10 - TRẮC NGHIỆM.pptxLỊCH SỬ 12 - CHUYÊN ĐỀ 10 - TRẮC NGHIỆM.pptx
LỊCH SỬ 12 - CHUYÊN ĐỀ 10 - TRẮC NGHIỆM.pptx
 
Giải phẫu tim sau đại học- LÊ QUANG TUYỀN
Giải phẫu tim sau đại học- LÊ QUANG TUYỀNGiải phẫu tim sau đại học- LÊ QUANG TUYỀN
Giải phẫu tim sau đại học- LÊ QUANG TUYỀN
 
PLĐC-chương 1 (1).ppt của trường ĐH Ngoại thương
PLĐC-chương 1 (1).ppt của trường  ĐH Ngoại thươngPLĐC-chương 1 (1).ppt của trường  ĐH Ngoại thương
PLĐC-chương 1 (1).ppt của trường ĐH Ngoại thương
 
Văn 7. Truyện ngụ ngôn Rùa và thỏ+ Viết PT nhân vật.docx
Văn 7. Truyện ngụ ngôn Rùa và thỏ+ Viết PT nhân vật.docxVăn 7. Truyện ngụ ngôn Rùa và thỏ+ Viết PT nhân vật.docx
Văn 7. Truyện ngụ ngôn Rùa và thỏ+ Viết PT nhân vật.docx
 
Cau-Trắc-Nghiệm-TTHCM-Tham-Khảo-THI-CUỐI-KI.pdf
Cau-Trắc-Nghiệm-TTHCM-Tham-Khảo-THI-CUỐI-KI.pdfCau-Trắc-Nghiệm-TTHCM-Tham-Khảo-THI-CUỐI-KI.pdf
Cau-Trắc-Nghiệm-TTHCM-Tham-Khảo-THI-CUỐI-KI.pdf
 

C10 generic algorithms

  • 1. Kỹ thuật lập trình 010101010101010110000101010101010101011000010101010101010101100001 010101010010101010010101010101001010101001010101010100101010100101 101001100011001001001010100110001100100100101010011000110010010010 110010110010001000001011001011001000100000101100101100100010000010 010101010101010110000101010101010101011000010101010101010101100001 010101010010101010010101010101001010101001010101010100101010100101 101001100011001001001010100110001100100100101010011000110010010010 110010110010001000001011001011001000100000101100101100100010000010 010101010101010110000101010101010101011000010101010101010101100001 010101010010101010010101010101001010101001010101010100101010100101 101001100011001001001010100110001100100100101010011000110010010010 110010110010001000001011001011001000100000101100101100100010000010 12/25/2007 y = A*x + B*u; x = C*x + d*u; StateController start() stop() LQGController start() stop() Chương 10: Thuật toán tổng quát
  • 2. 2Chương 10: Thuật toán tổng quát Nội dung chương 10 10.1 Tổng quát hóa kiểu dữ liệu phần tử 10.2 Tổng quát hóa phép toán cơ sở 10.3 Tổng quát hóa phương pháp truy lặp phần tử
  • 3. 3Chương 10: Thuật toán tổng quát 10.1 Tổng quát hóa kiểu dữ liệu phần tử Thực tế: — Khoảng 80% thời gian làm việc của một người thư ký văn phòng trước ₫ây (và hiện nay ở nhiều nơi) sử dụng cho công việc tìm kiếm, sắp xếp, ₫ối chiếu, so sánh,.... tài liệu và hồ sơ — Trung bình, khoảng 80% mã chương trình và thời gian thực hiện chương trình dành cho thực hiện các thuật toán ít liên quan trực tiếp tới bài toán ứng dụng cụ thể, mà liên quan tới tìm kiếm, sắp xếp, lựa chọn, so sánh... dữ liệu Dữ liệu ₫ược quản lý tốt nhất trong các cấu trúc dạng "container" (vector, list, map, tree, queue,...) Vấn ₫ề xây dựng hàm áp dụng cho các "container": Nhiều hàm chỉ khác nhau về kiểu dữ liệu tham số áp dụng, không khác nhau về thuật toán Giải pháp: Xây dựng khuôn mẫu hàm, tổng quát hóa kiểu dữ liệu phần tử
  • 4. 4Chương 10: Thuật toán tổng quát Ví dụ: Thuật toán tìm ₫ịa chỉ phần tử ₫ầu tiên trong một mảng có giá trị lớn hơn một số cho trước: template <typename T> T* find_elem(T *first, T* last, T k) { while (first != last && !(*first > k)) ++first; return first; } void main() { int a[] = { 1, 3, 5, 2, 7, 9, 6 }; int *p = find_elem(a,a+7,4); if (p != a+7) { cout << "First number > 4 :" << *p; p = find_elem(p+1,a+7,4); if (p != a+7) cout << "Second number > 4:" << *p; } double b[] = { 1.5, 3.2, 5.1, 2.4, 7.6, 9.7, 6.5 }; double *q = find_elem(b+2,b+6,7.0); *q = 7.0; ... }
  • 5. 5Chương 10: Thuật toán tổng quát Ví dụ: Thuật toán cộng hai vector, kết quả lưu vào vector thứ ba #include <assert.h> #include "myvector.h" template <typename T> void addVector(const Vector<T>& a, const Vector<T>& b, Vector<T>& c) { assert(a.size() == b.size() && a.size() == c.size()); for (int i= 0; i < a.size(); ++i) c[i] = a[i] + b[i]; } template <typename T> Vector<T> operator+(const Vector<T>&a, const Vector<T>& b) { Vector<T> c(a.size()); addVector(a,b,c); return c; }
  • 6. 6Chương 10: Thuật toán tổng quát 10.2 Tổng quát hóa phép toán cơ sở Vấn ₫ề: Nhiều thuật toán chỉ khác nhau ở một vài phép toán (cơ sở) trong khi thực hiện hàm Ví dụ: — Các thuật toán tìm ₫ịa chỉ phần tử ₫ầu tiên trong một mảng số nguyên có giá trị lớn hơn, nhỏ hơn, lớn hơn hoặc bằng, nhỏ hơn hoặc bằng, ... một số cho trước — Các thuật toán cộng, trừ, nhân, chia,... từng phần tử của hai mảng số thực, kết quả lưu vào một mảng mới — Các thuật toán cộng, trừ, nhân, chia,... từng phần tử của hai vector (hoặc của hai danh sách, hai ma trận, ...) Giải pháp: Tổng quát hóa thuật toán cho các phép toán cơ sở khác nhau!
  • 7. 7Chương 10: Thuật toán tổng quát template <typename COMP> int* find_elem(int* first, int* last, int k, COMP comp) { while (first != last && !comp(*first, k)) ++first; return first; } bool is_greater(int a, int b) { return a > b; } bool is_less(int a, int b) { return a < b; } bool is_equal(int a, int b) { return a == b;} void main() { int a[] = { 1, 3, 5, 2, 7, 9, 6 }; int* alast = a+7; int* p1 = find_elem(a,alast,4,is_greater); int* p2 = find_elem(a,alast,4,is_less); int* p3 = find_elem(a,alast,4,is_equal); if (p1 != alast) cout << "First number > 4 is " << *p1; if (p2 != alast) cout << "First number < 4 is " << *p2; if (p3 != alast) cout << "First number = 4 is at index " << p3 - a; char c; cin >> c; }
  • 8. 8Chương 10: Thuật toán tổng quát Tham số khuôn mẫu cho phép toán Có thể là một hàm, ví dụ bool is_greater(int a, int b){ return a > b; } bool is_less(int a, int b) { return a < b; } int add(int a, int b) { return a + b; } int sub(int a, int b) { return a - b; } ... Hoặc tốt hơn hết là một ₫ối tượng thuộc một lớp có hỗ trợ (nạp chồng) toán tử gọi hàm => ₫ối tượng hàm, ví dụ struct Greater { bool operator()(int a, int b) { return a > b; } }; struct Less { bool operator()(int a, int b) { return a < b; } }; struct Add { int operator()(int a, int b) { return a + b; } }; ...
  • 9. 9Chương 10: Thuật toán tổng quát Ví dụ sử dụng ₫ối tượng hàm void main() { int a[] = { 1, 3, 5, 2, 7, 9, 6 }; int* alast = a+7; Greater greater; Less less; int* p1 = find_elem(a,alast,4,greater); int* p2 = find_elem(a,alast,4,less); if (p1 != alast) cout << "First number > 4 is " << *p1; if (p2 != alast) cout << "First number < 4 is " << *p2; p1 = find_elem(a,alast,4,Greater()); p2 = find_elem(a,alast,4,Less()); char c; cin >> c; }
  • 10. 10Chương 10: Thuật toán tổng quát Ưu ₫iểm của ₫ối tượng hàm Đối tượng hàm có thể chứa trạng thái Hàm toán tử () có thể ₫ịnh nghĩa inline => tăng hiệu suất template <typename OP> void apply(int* first, int* last, OP& op) { while (first != last) { op(*first); ++first; } } class Sum { int val; public: Sum(int init = 0) : val(init) {} void operator()(int k) { val += k; } int value() const { return val; } };
  • 11. 11Chương 10: Thuật toán tổng quát class Prod { int val; public: Prod(int init=1): val(init) {} void operator()(int k) { val *= k; } int value() const { return val; } }; struct Negate {void operator()(int& k) { k = -k;} }; struct Print { void operator()(int& k) { cout << k << ' ';} }; void main() { int a[] = {1, 2, 3, 4, 5, 6, 7}; Sum sum_op; Prod prod_op; apply(a,a+7,sum_op); cout << sum_op.value() << endl; apply(a,a+7,prod_op); cout << prod_op.value() << endl; apply(a,a+7,Negate()); apply(a,a+7,Print()); char c; cin >> c; }
  • 12. 12Chương 10: Thuật toán tổng quát Kết hợp 2 bước tổng quát hóa template <typename T, typename COMP> T* find_elem(T* first, T* last, T k, COMP comp) { while (first != last && !comp(*first, k)) ++first; return first; } template <typename T, typename OP> void apply(T* first, T* last, OP& op) { while (first != last) { op(*first); ++first; } }
  • 13. 13Chương 10: Thuật toán tổng quát Khuôn mẫu lớp cho các ₫ối tượng hàm template <typename T> struct Greater{ bool operator()(const T& a, const T& b) { return a > b; } }; template <typename T> struct Less{ bool operator()(const T& a, const T& b) { return a > b; } }; template <typename T> class Sum { T val; public: Sum(const T& init = T(0)) : val(init) {} void operator()(const T& k) { val += k; } T value() const { return val; } };
  • 14. 14Chương 10: Thuật toán tổng quát template <typename T> struct Negate { void operator()(T& k) { k = -k;} }; template <typename T> struct Print { void operator()(const T& k) { cout << k << ' ';} }; void main() { int a[] = { 1, 3, 5, 2, 7, 9, 6 }; int* alast = a+7; int* p1 = find_elem(a,alast,4,Greater<int>()); int* p2 = find_elem(a,alast,4,Less<int>()); if (p1 != alast) cout << "nFirst number > 4 is " << *p1; if (p2 != alast) cout << "nFirst number < 4 is " << *p2; Sum<int> sum_op; apply(a,a+7,sum_op); cout<< "nSum of the sequence " << sum_op.value() << endl; apply(a,a+7,Negate<int>()); apply(a,a+7,Print<int>()); char c; cin >> c; }
  • 15. 15Chương 10: Thuật toán tổng quát 10.3 Tổng quát hóa truy lặp phần tử Vấn ₫ề 1: Một thuật toán (tìm kiếm, lựa chọn, phân loại, tính tổng, ...) áp dụng cho một mảng, một vector, một danh sách họăc một cấu trúc khác thực chất chỉ khác nhau ở cách truy lặp phần tử Vấn ₫ề 2: Theo phương pháp truyền thống, ₫ể truy lặp phần tử của một cấu trúc "container", nói chung ta cần biết cấu trúc ₫ó ₫ược xây dựng như thế nào — Mảng: Truy lặp qua chỉ số hoặc qua con trỏ — Vector: Truy lặp qua chỉ số — List: Truy lặp qua quan hệ móc nối (sử dụng con trỏ) — ...
  • 16. 16Chương 10: Thuật toán tổng quát Ví dụ thuật toán copy Áp dụng cho kiểu mảng thô template <class T> void copy(const T* s, T* d, int n) { while (n--) { *d = *s; ++s; ++d; } } Áp dụng cho kiểu Vector template <class T> void copy(const Vector<T>& s, Vector<T>& d) { for (int i=0; i < s.size(); ++i) d[i] = s[i]; } Áp dụng cho kiểu List template <class T> void copy(const List<T>& s, List<T>& d) { ListItem<T> *sItem=s.getHead(), *dItem=d.getHead(); while (sItem != 0) { dItem->data = sItem->data; dIem = dItem->getNext(); sItem=sItem->getNext(); } }
  • 17. 17Chương 10: Thuật toán tổng quát Ví dụ thuật toán find_max Áp dụng cho kiểu mảng thô template <typename T> T* find_max(T* first, T* last) { T* pMax = first; while (first != last) { if (*first > *pMax) pMax = first; ++first; } return pMax; } Áp dụng cho kiểu Vector template <typename T> T* find_max(const Vector<T>& v) { int iMax = 0; for (int i=0; i < v.size(); ++ i) if (v[i] > v[iMax]) iMax = i; return &v[iMax]; }
  • 18. 18Chương 10: Thuật toán tổng quát Áp dụng cho kiểu List (₫ã làm quen): template <typename T> ListItem<T>* find_max(List<T>& l) { ListItem<T> *pItem = l.getHead(); ListItem<T> *pMaxItem = pItem; while (pItem != 0) { if (pItem->data > pMaxItem->data) pMaxItem = pItem; pItem = pItem->getNext(); } return pMaxItem; } Cần tổng quát hóa phương pháp truy lặp phần tử!
  • 19. 19Chương 10: Thuật toán tổng quát Bộ truy lặp (iterator) Mục ₫ích: Tạo một cơ chế thống nhất cho việc truy lặp phần tử cho các cấu trúc dữ liệu mà không cần biết chi tiết thực thi bên trong từng cấu trúc Ý tưởng: Mỗi cấu trúc dữ liệu cung cấp một kiểu bộ truy lặp riêng, có ₫ặc tính tương tự như một con trỏ (trong trường hợp ₫ặc biệt có thể là một con trỏ thực) Tổng quát hóa thuật toán copy: template <class Iterator1, class Iterator2> void copy(Iterator1 s, Iterator2 d, int n) { while (n--) { *d = *s; ++s; ++d; } } Các phép toán áp dụng ₫ược tương tự con trỏ
  • 20. 20Chương 10: Thuật toán tổng quát Tổng quát hóa thuật toán find_max: template <typename ITERATOR> ITERATOR find_max(ITERATOR first, ITERATOR last) { ITERATOR pMax = first; while (first != last) { if (*first > *pMax) pMax = first; ++first; } return pMax; } Các phép toán áp dụng ₫ược tương tự con trỏ
  • 21. 21Chương 10: Thuật toán tổng quát Bổ sung bộ truy lặp cho kiểu Vector Kiểu Vector lưu trữ dữ liệu dưới dạng một mảng => có thể sử dụng bộ truy lặp dưới dạng con trỏ! template <class T> class Vector { int nelem; T* data; public: ... typedef T* Iterator; Iteratator begin() { return data; } Iteratator end() { return data + nElem; } }; void main() { Vector<double> a(5,1.0),b(6); copy(a.begin(),b.begin(),a.size()); ... }
  • 22. 22Chương 10: Thuật toán tổng quát Bổ sung bộ truy lặp cho kiểu List template <class T> class ListIterator { ListItem<T> *pItem; ListIterator(ListItem<T>* p = 0) : pItem(p) {} friend class List<T>; public: T& operator*() { return pItem->data; } ListIterator<T>& operator++() { if (pItem != 0) pItem = pItem->getNext(); return *this; } friend bool operator!=(ListIterator<T> a, ListIterator<T> b) { return a.pItem != b.pItem; } };
  • 23. 23Chương 10: Thuật toán tổng quát Khuôn mẫu List cải tiến template <class T> class List { ListItem<T> *pHead; public: ... ListIterator<T> begin() { return ListIterator<T>(pHead); } ListIterator<T> end() { return ListIterator<T>(0); } };
  • 24. 24Chương 10: Thuật toán tổng quát Bài tập về nhà Xây dựng thuật toán sắp xếp tổng quát ₫ể có thể áp dụng cho nhiều cấu trúc dữ liệu tập hợp khác nhau cũng như nhiều tiêu chuẩn sắp xếp khác nhau. Viết chương trình minh họa. Xây dựng thuật toán cộng/trừ/nhân/chia từng phần tử của hai cấu trúc dữ liệu tập hợp bất kỳ. Viết chương trình minh họa.