' std::shuffle '是否保证在不同向量上具有相同种子的相同顺序?
Does `std::shuffle` guarantees same order with same seed on different vectors?
我有两个元素数量相同的向量,但它们的类型大小完全不同。我需要对它们进行洗牌,以便它们在洗牌后具有完全相同的顺序(一个向量中的每个元素与另一个向量中的每个元素相关)。我找到了这样做的方法:
// sizeof(a[0]) != sizeof(b[0])
// a.size() == b.size()
{
std::mt19937 g(same_seed);
std::shuffle(a.begin(), a.end(), g);
}
{
std::mt19937 g(same_seed);
std::shuffle(b.begin(), b.end(), g);
}
我能保证两个向量会以相同的方式洗牌吗?这个实现是依赖的吗?我在std::shuffle
规范中有这样的保证吗?
规范中有一个关于shuffle的有趣声明:
备注:如果此函数的实现使用随机数,则对象
g
应作为实现的随机性来源。
即便如此,那句话也帮不了你。"备注"部分是规范文本,所以这就是说g
将提供随机数来确定洗牌顺序。然而,这并不能说明g
是决定排列的唯一因素。
虽然容器值的大小可能无关紧要,但不能保证类型的某些属性不会影响某些内容。例如,如果值类型是可复制的,则实现可能会使用使用稍微不同算法的函数的不同版本。但是,如果它是一个寄存器大小的值,则可能不会。
简而言之,不,std::shuffle
不能保证你所寻找的。
相关文章:
- CMake-按正确顺序将项目与C运行时对象文件链接
- 函数调用中参数的顺序重要吗
- 为什么不;名字在地图上是按顺序排列的吗
- 将Integer转换为4字节的unsined字符矢量(按大端字节顺序)
- 数到第n个楼梯的路(顺序无关紧要)
- 优先顺序:智能指针和类析构函数
- 在循环中按顺序遍历成员变量
- 独立读取-修改-写入顺序
- QML按钮点击功能执行顺序
- C++中数据类型修饰符的顺序
- 当比特(而不是字节)的顺序至关重要时的持久性
- C++从其他 constexpr 创建 lambda 不能按顺序执行 Constexpr
- 通过选项卡的文本设置QTabWidget顺序
- c++11评估顺序(未定义的行为)
- 如何在C++中递归地按相反顺序打印集合
- 给定顺序中的事件处理
- 具有包含其他对象的类的对象创建顺序
- 如何通过替换顺序代码的while循环来添加OpenMP for循环
- 遍历顺序由 std::文件系统directory_iterator给出
- ' std::shuffle '是否保证在不同向量上具有相同种子的相同顺序?