例如,我将如何重写下面的代码,使用没有循环的 STL 算法?
vector<double> pizzaBox;
int biggestSlice = 0;
for (int* p = &pizzaBox[0]; p != pizzaBox[pizzaBox.size()]; p++) {
if(*p > biggestSlice)
biggestSlice = *p;
}
最佳答案
假设您实际上是指 vector<int>
,并在更正循环结束条件后,您可以使用 max_element
算法在这里:
int biggestSlice = *max_element(pizzaBox.begin(), pizzaBox.end());
(注意 max_element
返回一个迭代器,因此我在分配给 biggestSlice
之前取消引用返回值。)
当 vector 为空时,这当然不再有效(= 产生未定义的行为)。您需要在 取消引用函数的返回值之前对此进行显式测试。
关于c++ - 使用 STL 算法重写的指针的循环示例,没有循环?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5978047/