- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
为了以相同的顺序打乱两个 vector ,很容易做类似的事情
whatever_rng_type rng2(rng1);
std::shuffle(vec1.begin(), vec1.end(), rng1);
std::shuffle(vec2.begin(), vec2.end(), rng2);
其中相同的 RNG 状态用于两个 shuffle。但是,我没有看到任何要求这些洗牌实际上在
standard draft 中产生相同的顺序。我检查了。
std::shuffle
必须使用提供的 RNG 作为其随机源,但实现也可能会执行某些操作,例如为不同的元素大小采用不同的代码路径。也许实现可能对某些类型使用 AVX512 收集/分散指令,而对其他类型使用通用的非矢量化代码路径,这可能会影响结果排序。
最佳答案
我仔细检查了标准并同意没有任何要求 shuffle 对其使用随机数做出任何保证。它简单地说:
"To the extent that the implementation of this function makes use of random numbers, the object referenced by g shall serve as the implementation’s source of randomness.".
move_together
保持对 vector 的引用的对象,然后传递
shuffle
iterator
s 具有指向
move_together
的指针对象和正在处理的 vector 中的索引。您可以通过前面的
move_together
来简化这一点。对象并直接在迭代器中具有指向两个 vector 的指针或引用。当迭代器被取消引用时,它们返回然后支持
swap
的代理对象。平。
std::shuffle
实现。对于另一个需要更完整的迭代器或代理的编译器....
#include <iostream>
#include <vector>
#include <random>
#include <string>
#include <algorithm>
template <typename T1, typename T2>
struct move_together;
template <typename T1, typename T2>
struct proxy
{
const move_together<T1, T2>* p_;
const size_t i_;
proxy& operator=(const proxy& rhs);
};
template <typename T1, typename T2>
struct move_together
{
move_together(std::vector<T1>& v1, std::vector<T2>& v2)
: v1_(v1), v2_(v2)
{ }
struct iterator
{
using iterator_category = std::random_access_iterator_tag;
using difference_type = ssize_t;
using value_type = proxy<T1, T2>;
using pointer = value_type*;
using reference = value_type&;
const move_together* p_;
size_t i_;
value_type operator*() { return {p_, i_}; }
bool operator==(const iterator& rhs) const { return i_ == rhs.i_; }
bool operator!=(const iterator& rhs) const { return !(*this == rhs); }
difference_type operator-(const iterator& rhs) const
{ return i_ - rhs.i_; }
iterator operator+(int distance) const
{ return {p_, i_ + distance}; }
iterator operator++(int) { auto x = *this; ++i_; return x; }
iterator& operator++() { ++i_; return *this; }
};
iterator begin() { return {this, 0}; }
iterator end() { return {this, std::min(v1_.size(), v2_.size())}; }
std::vector<T1>& v1_;
std::vector<T2>& v2_;
};
template <typename T1, typename T2>
proxy<T1, T2>& proxy<T1, T2>::operator=(const proxy<T1, T2>& rhs)
{
p_->v1_[i_] = rhs.p_->v1_[rhs.i_];
p_->v2_[i_] = rhs.p_->v2_[rhs.i_];
}
template <typename T1, typename T2>
void swap(proxy<T1, T2> lhs, proxy<T1, T2> rhs) {
using std::swap;
swap(lhs.p_->v1_[lhs.i_], rhs.p_->v1_[rhs.i_]);
swap(lhs.p_->v2_[lhs.i_], rhs.p_->v2_[rhs.i_]);
}
int main()
{
std::vector<int> v1{ {1, 2, 3, 4, 5} };
std::vector<std::string> v2{ {"one", "two", "three", "four", "five"} };
std::random_device rd;
std::mt19937 rng{rd()};
move_together m{v1, v2};
std::shuffle(m.begin(), m.end(), rng);
for (const auto& x : v1) std::cout << x << '/';
std::cout << '\n';
for (const auto& x : v2) std::cout << x << '/';
std::cout << '\n';
}
关于c++ - std::shuffle 的顺序可以依赖于 RNG 之外的任何东西吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64012057/
我开发了一个 RNG 算法并生成随机数,现在我想测试生成的输出的随机性。我从 nist(sts) 下载了一个测试套件。有一个选项可以提供输入二进制文件来测试随机性。但我不知道如何生成这些二进制文件。我
因此,我编写了一个函数(以及一个 RNG 函数,上述函数调用该函数)来将随机数量的星号打印到控制台窗口,直到达到 90 个空格。星号代表汽车的运动,90个空格是轨道的长度。下面我包含的代码打印随机数量
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 8 年前。 Improve
我正在尝试为我的模拟器重现一些行为。 我有一个百分比支票,从 30% 到 70% 不等。问题是它不是严格随机的。这是我提取的实时数据: https://docs.google.com/spreadsh
这个问题在这里已经有了答案: How to generate a random integer in the range [0,n] from a stream of random bits wit
我目前正在实现一个代表 52 张牌的牌组的 Deck 类。它使用 boost Random 库来洗牌代表卡片的整数。 #include #include #include "constants.h
在本文的最后一个示例 (http://www.daniweb.com/software-development/cpp/threads/1769/c-random-numbers) 中,作者声称这是一
我想使用 在我的 C++ 应用程序中使用多个 RNG .播种它们的最佳方法是什么?我担心当使用来自单个 RNG 的随机数为每个 RNG 播种时,来自不同 RNG 的随机数会过于相关。 最佳答案 如果
现在我正在使用 Mersenne Twister RNG 并执行 Fisher-Yates 洗牌算法 100 次: std::vector shufCards; for(int i =
我正在开发一款纸牌游戏,我需要洗牌算法来做得很好,并且每次游戏运行时都不同,并且没有可预测的纸牌序列。 我正在使用 Mersenne twister 算法,但它仍然需要一个种子,所以实际上,虽然它产生
我可以使用两种方法中的一种来创建具有两个重要特征的伪随机数序列 - (1) 它可以在不同的机器上重现,并且 (2) 该序列从不重复范围内的数字,直到所有数字都被发出. 我的问题是 - 这些方法中的任何
我有一段冗长而复杂的源代码,它使用带有修复种子的随机数生成器。 这段代码是一个模拟器,这个模拟器的参数就是这个RNG给出的随机值。当我在同一台机器上执行代码时,无论我尝试多少次,输出都是一样的。但是当
我在想这个问题。我听说全局变量不好,它们会损害代码的可维护性、可用性、可重用性等。但在这种情况下,我还能做什么呢?也就是说,我有一个“伪随机数生成器”(PRNG),正如人们所知,它们涉及一种内部状态,
回复 this question我运行了以下 VBA 实验: Sub Test() Dim i As Long, A As Variant Dim count1 As Long, co
我知道我可以用例如设置 RNGversion RNGversion("3.5.2") 但是是否可以查询我当前使用的 R 版本? 编辑: 我的问题是版本 3.6.0 发生了一些变化,这在 RNGkind
我今天刚开始学习JavaScript,这个很简单的问题给我带来了麻烦。这只是较大代码段的一部分,但我将其隔离以尝试修复它。这是: document.write(blarg()); func
我制作了一个随机数生成器,如果有人在没有数字的情况下使用它,它会崩溃如何确保用户输入是否是字符串,它不会崩溃,而是说“无效参数”? static int random; static String s
好吧,我正在编写一个与 cpu 对抗的程序,但每次它都会先失败然后致命,我会分解我的代码,以便让你们更容易提供帮助。 进口: import javax.swing.JOptionPane; impor
我的问题是http://rcpp-devel.r-forge.r-project.narkive.com/qJMEsvOK/setting-the-r-random-seed-from-rcpp的后续
作为一个学习 Haskell 的 Java 人,我已经习惯了思考一切的新方法,但我花了半天时间尝试用简单的 RNG 实现一些东西,但一无所获。在 Java 中,我可以创建一个静态 RNG 并使用 Cl
我是一名优秀的程序员,十分优秀!