打乱数组的10%
Shuffle 10% of an array
本文关键字:数组 更新时间:2024-09-27
如何仅对数组的10%进行混洗,使90%不受影响,并随机对10%进行混移?
我对数组应用了排序算法。我曾想过使用rand()
,但我不知道如何将洗牌限制在10%以内。
可能可以改进,但您可以执行以下操作:
template <typename Rnd, typename IT>
void partial_shuffle(Rnd&& rnd, IT begin, IT end, std::size_t k)
{
std::vector<std::size_t> indexes(std::distance(begin, end));
std::iota(indexes.begin(), indexes.end(), 0);
// Select subset to shuffle
std::shuffle(indexes.begin(), indexes.end(), rnd);
std::vector<std::decay_t<decltype(*begin)>> subset;
for (std::size_t i = 0; i != k; ++i) {
subset.push_back(*(begin + indexes[i]));
}
// Shuffle the subset
std::shuffle(subset.begin(), subset.end(), rnd);
// place them at correct position
for (std::size_t i = 0; i != k; ++i) {
*(begin + indexes[i]) = subset[i];
}
}
演示
相关文章:
- Mongodb c++驱动程序:如何查询元素的数组
- 将数组的地址分配给变量并删除
- 从C++本机插件更新Vector3数组
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 数组索引的值没有增加
- 将对象数组的引用传递给函数
- 为char数组调整zlib-zpipe
- 2D数组来自文本输入,中间有空格
- std::向量与传递值的动态数组
- 在c++中用vector填充一个简单的动态数组
- 使用strcpy将char数组的元素复制到另一个数组
- 使用指针从C++中的数组中获取最大值
- C++使用整数的压缩数组初始化对象
- 告诉一个 const char 数组,除了编译时 C 样式的字符串外,它不以 '