adjfind1.cpp

来自「stl自带源码」· C++ 代码 · 共 55 行

CPP
55
字号
/* The following code example is taken from the book * "The C++ Standard Library - A Tutorial and Reference" * by Nicolai M. Josuttis, Addison-Wesley, 1999 * * (C) Copyright Nicolai M. Josuttis 1999. * Permission to copy, use, modify, sell and distribute this software * is granted provided this copyright notice appears in all copies. * This software is provided "as is" without express or implied * warranty, and with no claim as to its suitability for any purpose. */#include "algostuff.hpp"using namespace std;// return whether the second object has double the value of the firstbool doubled (int elem1, int elem2){   return elem1 * 2 == elem2;}int main(){   vector<int> coll;   coll.push_back(1);   coll.push_back(3);   coll.push_back(2);   coll.push_back(4);   coll.push_back(5);   coll.push_back(5);   coll.push_back(0);   PRINT_ELEMENTS(coll,"coll: ");   // search first two elements with equal value   vector<int>::iterator pos;   pos = adjacent_find (coll.begin(), coll.end());   if (pos != coll.end()) {       cout << "first two elements with equal value have position "            << distance(coll.begin(),pos) + 1            << endl;   }   // search first two elements for which the second has double the value of the first   pos = adjacent_find (coll.begin(), coll.end(),   // range                        doubled);                   // criterion   if (pos != coll.end()) {       cout << "first two elements with second value twice the "            << "first have pos. "            << distance(coll.begin(),pos) + 1            << endl;   }}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?