容器自身不能使用算法,但两个容器中的游标可以限定容器中使用算法的元素。既然这样,算法不直接受到容器的限制,而是通过采用游标,算法才能够得到支持。此外,很多次你会遇到传递一个已经准备好了的函数(以前提到的声明:predicate)作为参数,你也可以传递以前的旧值。
下面的例子演示了怎样使用算法:
| //程序:测试分数统计 //目的:通过对向量中保存的分数的操作说明怎样使用算法 #include <algorithm> //如果要使用算法函数,你必须要包含这个头文件。 #include <numeric> // 包含accumulate(求和)函数的头文件 #include <vector> #include <iostream> using namespace std; int testscore[] = {67, 56, 24, 78, 99, 87, 56}; //判断一个成绩是否通过了考试 bool passed_test(int n) { return (n >= 60); } // 判断一个成绩是否不及格 bool failed_test(int n) { return (n < 60); } int main(int argc, char* argv[]) { int total; // 初始化向量,使之能够装入testscore数组中的元素 vector <int> vecTestScore(testscore, testscore + sizeof(testscore) / sizeof(int)); vector <int>::iterator vi; // 排序并显示向量中的数据 sort(vecTestScore.begin(), vecTestScore.end()); cout << "Sorted Test Scores:" << endl; for (vi=vecTestScore.begin(); vi != vecTestScore.end(); vi++) { cout << *vi << ", "; } cout << endl; // 显示统计信息 // min_element 返回一个 _iterator_ 类型的对象,该对象指向值最小的那个元素。 //“*”运算符提取元素中的值。 vi = min_element(vecTestScore.begin(), vecTestScore.end()); cout << "The lowest score was " << *vi << "." << endl; //与min_element类似,max_element是选出最大值。 vi = max_element(vecTestScore.begin(), vecTestScore.end()); cout << "The highest score was " << *vi << "." << endl; // 使用声明函数(predicate function,指vecTestScore.begin()和vecTestScore.end())来确定通过考试的人数。 cout << count_if(vecTestScore.begin(), vecTestScore.end(), passed_test) << " out of " << vecTestScore.size() << " students passed the test" << endl; // 确定有多少人考试挂了 cout << count_if(vecTestScore.begin(), vecTestScore.end(), failed_test) <<" out of " << vecTestScore.size() << " students failed the test" << endl; //计算成绩总和 total = accumulate(vecTestScore.begin(), vecTestScore.end(), 0); // 计算显示平均成绩 cout << "Average score was " <<(total / (int)(vecTestScore.size())) << endl; return 0; } |