有没有一种惯用的方法可以在不存储变换或不必要地重新计算的情况下找到数组变换的最小/最大值?
Is there an idiomatic way to find min/max of transform of array without storing the transform or needlessly recalculating?
我有一个数据类型T
数组,我必须对其执行一些long_calculation(const T&)
并找到其最小值。因为数组非常大,并且函数占用了我大量的运行时,所以我想以多线程方式和最有效的方式完成它。最接近我正在寻找的东西似乎是std::min_element
但它不是一个完美的选择,因为它似乎在内部不能使用它计算的值,它甚至没有返回我想要的值。这迫使我做如下事情。
const auto iter = std::min_element(std::execution::par_unseq,
my_container.begin(), my_container.end(), [](const T& t1, const T& t2) {
return long_calculation(t1) < long_calculation(t2);
}
const auto value = long_calculation(*T1);
该标准最多保证 N-1 比较,但不存储long_calculation
的结果,我期望 2N-2 计算而不是最佳 N。或者更确切地说是 2N-1,因为最后一行。
另一方面,预先计算值并进行搜索会执行 Nlong_calculation
s,但会使用额外的存储空间O(N)
在我的情况下也必须动态分配。
有没有办法在标准或某些第三方库中以通用方式执行此操作?如果没有,最合适的方法是什么?理想的解决方案是一个多线程函数,可以像这样调用。
const auto min_value = min_of_transform(
my_container.begin(), my_container.end(), long_calculation);
使用std::transform_reduce
算法:
std::transform_reduce(std::execution::par_unseq, my_container.begin(), my_container.end(),
std::numeric_limits<T>::max(),
[](const auto& x, const auto& y) { return std::min(x, y); },
long_calculation);
相关文章:
- 在没有太多条件句的情况下,我如何避免被零除
- 为什么在没有显式默认构造函数的情况下,将另一个结构封装在联合中作为成员的结构不能编译
- 在未初始化映射的情况下,将值插入到映射的映射中
- 是默认情况下分配给char数组常量的值
- 为什么我不能在不创建字符串变量的情况下使用函数的字符串输出
- 如何在不产生任何垃圾的情况下获得C中的像素
- 在已经使用Git的情况下减少编译时间
- 为什么在Windows上的VS 2019和Clang 9中"size_t"在没有标题的情况下工作
- 如何在没有信号的情况下从C++执行QML插槽
- 如何在不知道向量大小的情况下输入向量内部的向量?
- 为什么在某些情况下不写入此文件?
- 为什么Mat类的两个对象可以在不重载运算符+的情况下添加
- 在没有Xcode的情况下在Mac捆绑包中嵌入框架
- UE4-如何在给定4个屏幕坐标的情况下缩放纹理或材质
- 为什么需要复制构造函数,在哪些情况下它们非常有用
- 在C++中如何在没有pow的情况下进行基础计算
- 松弛原子与无同步情况下的记忆连贯性
- 在 Windows 上,是否可以让 dll 在不使用 PATH 环境变量的情况下在另一个文件夹中查找依赖项?
- 我是c ++的新手,你能解释一下在这种情况下的指针吗
- 有没有一种惯用的方法可以在不存储变换或不必要地重新计算的情况下找到数组变换的最小/最大值?