c++ - 使用 STL 算法重写的指针的循环示例,没有循环?

标签 c++ algorithm loops stl for-loop

例如,我将如何重写下面的代码,使用没有循环的 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/

相关文章:

c++ - LLDB Python 脚本中的指针算法

Javascript:在对象数组中的对象上调用方法

php - 以有效和简单的方式实现层次结构、父/子关系

php - 双败赛程

excel - 编译错误: invalid qualifier when looping through worksheets

c++ - 功能代码在使用两次时中断

c++ - 在 C++ 中转换树

c++ - 为什么 65537 不使用 CryptoPP 将 base64URL 编码为 "AQAB"?

algorithm - graph - 如何避免在深度优先搜索中重复处理相同的边缘?

algorithm - 如何在 bnfinit() 中构造字段?