C++函數(shù)對(duì)象(也稱(chēng)為仿函數(shù)或functor)在算法中扮演著非常重要的角色
<
進(jìn)行比較。但是,有時(shí)我們需要使用自定義的比較邏輯。這時(shí),我們可以創(chuàng)建一個(gè)函數(shù)對(duì)象作為比較器,并將其傳遞給算法。例如,std::sort
算法可以使用自定義的比較器對(duì)元素進(jìn)行降序排序。#include <algorithm>
#include <vector>
struct CustomComparator {
bool operator()(int a, int b) const {
return a > b;
}
};
int main() {
std::vector<int> vec = {3, 1, 4, 1, 5, 9};
std::sort(vec.begin(), vec.end(), CustomComparator());
return 0;
}
#include <iostream>
struct Fibonacci {
int operator()(int n) const {
if (n <= 1) return n;
return fibonacci(n - 1) + fibonacci(n - 2);
}
private:
int fibonacci(int n) const {
if (n <= 1) return n;
return fibonacci(n - 1) + fibonacci(n - 2);
}
};
int main() {
Fibonacci fib;
std::cout << "Fibonacci(10): " << fib(10) << std::endl;
return 0;
}
#include <iostream>
#include <cmath>
struct SquareRoot {
double operator()(double x) const {
return std::sqrt(x);
}
};
int main() {
SquareRoot sqrt;
std::cout << "Square root of 9: " << sqrt(9) << std::endl;
return 0;
}
總之,C++函數(shù)對(duì)象在算法中的作用主要是提供自定義的比較邏輯、傳遞狀態(tài)信息和封裝復(fù)雜操作。它們使我們可以更加靈活地使用STL算法,以滿足不同的需求。