- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我需要对从 1
到 N
的所有可能的数字集进行编程,以获得任意数量的 m
整数,无需排列。
由于我不知道如何更好地解释它,这里有一些例子:
对于 m = 2
vector<vector<int>> box;
int N = 5;
for(int i = 1; i <= N; i++) {
for(int j = N; j >= i; j--) {
vector<int> dummy;
dummy.push_back(i);
dummy.push_back(j);
box.push_back(dummy);
}
}
对于 m = 3
vector<vector<int>> box;
int N = 5;
for(int i = 1; i <= N; i++) {
for(int j = N; j >= i; j--) {
for(int k = N; k >= j; k--) {
vector<int> dummy;
dummy.push_back(i);
dummy.push_back(j);
dummy.push_back(k);
box.push_back(dummy);
}
}
}
这工作得很好,结果正是我需要的。但是就像已经提到的那样,m
可以是任意的,我懒得为 m = 37
或其他任何东西实现它。 N
和 m
是已知值,但会在程序运行时发生变化。必须有比 m = 37
情况下实现一行 37-for 循环更好的方法来实现这一点。有人能帮我吗?我有点无能为力:\
编辑:为了更好地解释我在这里寻找的是一些更多的例子。
假设 N = 5
和 m = 4
,1223
对我来说是一个可行的解决方案,124
不是因为它太短了。假设我已经找到 1223
作为解决方案,而不需要 2123
、2213
或此数字的任何其他排列。
edit2:或者,如果您更喜欢更直观(数学?)的问题表述,您可以这样做。
考虑 m
维度。当 m
为 2 时,您将得到一个 N
大小的矩阵。我正在寻找这个矩阵的上(或下)三角形,包括对角线。让我们移动到 m = 3
,矩阵变为 3 维立方体(如果您愿意,也可以是 Tensor),现在我正在寻找上(或下)四面体,包括对角平面。对于大于 3 的维度,我正在寻找包括超对角平面在内的超立方体的超四面体。
最佳答案
http://howardhinnant.github.io/combinations.html
The following generic algorithms permit a client to visit every combination or permuation of a sequence of length N, r items at time.
示例用法:
std::vector<std::vector<int>> box;
std::vector<int> v(N);
std::iota(begin(v), end(v), 1);
for_each_combination(begin(v), begin(v) + M, end(v), [](auto b, auto e) {
box.emplace_back(b, e);
return false;
});
上面的代码只是将每个组合插入到 box
中作为示例,但您可能不想真正这样做:假设 box
只是一个中介并且你的实际工作然后在其他地方使用它,你可以避免中介,直接在仿函数的主体中直接做你需要的任何工作。
这是一个 complete, working example使用提供的链接中的代码。
因为您想要的是重复的组合,而不仅仅是组合。下面是在 for_each_combination()
之上实现它的示例:
template<typename Func>
void for_each_combination_with_repetition(int categories, int slots, Func func) {
std::vector<int> v(slots + categories - 1);
std::iota(begin(v), end(v), 1);
std::vector<int> indices;
for_each_combination(begin(v), begin(v) + slots, end(v), [&](auto b, auto e) {
indices.clear();
int last = 0;
int current_element = 0;
for(;b != e; ++last) {
if (*b == last+1) {
indices.push_back(current_element);
++b;
} else {
++current_element;
}
}
func(begin(indices), end(indices));
return false;
});
}
维基百科 article on combinations很好地说明了这是在做什么:它获取数字 [0, N + M - 1) 的所有组合(不重复),然后寻找结果中的“差距”。间隙表示从一个元素的重复到下一个元素的重复的过渡。
您传递给该算法的仿函数被赋予一个范围,该范围包含指向包含您正在组合的元素的集合的索引。例如,如果你想从 {x,y} 的集合中获取所有三个元素的集合,你想要的结果是 {{x,x,x}, {x,x,y}, {x,y, y}, {y,y,y}},此算法通过将索引范围返回到(有序的)集合 {x,y} 中来表示:{{0,0,0}, {0,0,1} , {0,1,1}, {1,1,1}}。
所以通常要使用它,你有一个 vector 或包含你的元素的东西,并使用这个算法产生的范围作为该容器的索引。但是在您的情况下,由于元素只是从 1 到 N 的数字,您可以通过向每个索引加一来直接使用索引:
for_each_combination_with_repetition(N, M, [&](auto b, auto e) {
for(; b != e; ++b) {
int index = *b;
std::cout << index + 1 << " ";
}
std::cout << '\n';
});
另一种实现可以返回表示每个类别计数的 vector 。例如。较早的 {{x,x,x}, {x,x,y}, {x,y,y}, {y,y,y}} 结果可以表示为:{{3,0} {2, 1},{1,2},{0,3}}。修改实现以生成此表示,而不是像这样:
template<typename Func>
void for_each_combination_with_repetition(int categories, int slots, Func func) {
std::vector<int> v(slots + categories - 1);
std::iota(begin(v), end(v), 1);
std::vector<int> repetitions(categories);
for_each_combination(begin(v), begin(v) + slots, end(v), [&](auto b, auto e) {
std::fill(begin(repetitions), end(repetitions), 0);
int last = 0;
int current_element = 0;
for(;b != e; ++last) {
if (*b == last+1) {
++repetitions[current_element];
++b;
} else {
++current_element;
}
}
func(begin(repetitions), end(repetitions));
return false;
});
}
关于c++ - 如何在 C++ 中避免这种 for 循环困惑?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33879580/
我有一个程序可以打开一个窗口并快速改变背景颜色并随机弹出矩形和椭圆形。我的代码有效,但我不知道为什么,因为我没有在我的代码中调用 repaint() 函数。当我使用我个人的 update() 函数包含
var allRapidSpells = $$('input[value^=RSW]'); 谁能告诉我这是做什么的? 最佳答案 我敢猜测您正在使用 MooTools ,一个 JavaScript 框架
我有一个抽象父类,它有多个子类。我希望 child 能够拥有一个对于该 child 的每个实例都相同的变量。我不想将构造函数传递给 child 来告诉它它的名字,因为当它可以被硬编码时,这看起来很愚蠢
我刚刚在 Git 存储库上做了一些糟糕的事情,我不知道如何解决这个问题。我什至不知道我是怎么把它弄成这样的……! 在存储库(托管在 git hub 上)上,有 3 个我感兴趣的分支:master、br
我是 GIT 的新手,在理解提交日志图时遇到问题。 我感觉每条平行线都是一个分支。虽然我的源代码只有 2 个分支。我在下面提供的提交日志图中看到 3-4 条平行线(Microsoft Team Ser
我是 WPF 的新手,ScrollViewer 让我很沮丧。要么我只是没有“得到”它,要么它是一种有限的控制。 这是我的挫折: 水平滚动错误 水平滚动条仅在列表底部可见(我必须滚动到底部才能看到) 坏
那么 $('table.selectable td.capable input:text') 比 $('table.selectable td input:text') 更好吗?换句话说,指定一个类会
我刚刚完成了计算机图形学类(class),我们必须对光线追踪器进行编程。尽管所有结果都是正确的,但我对 OpenMP 的使用感到困惑(顺便说一句,这不是类(class)的一部分)。我有这个循环(C++
与 PatternSynonyms ( explicitly bidirectional form ),pattern-to-expr 方程实际上形成了一个函数,但拼写为大写(假设您最终得到正确类型的
我是 javascript/coffeescript 新手。 有人可以解释一下为什么这个 CoffeeScript/JavaScript 会毫无延迟地快速通过吗?我对第一种情况的想法是,它是对 upd
如果我调用document.getElementsByClassName('cl'),我会得到一个 HTMLCollection。它似乎包含 Element 对象而不是 HTMLElement 对象,
这是我本月的 azure payasyougo 使用费用。 我很难理解为什么我要为标准中型应用服务付费,我认为它会包含在计算时间中?我只运行一个云服务,这对于一个没有做太多事情的云服务来说似乎有点陡峭
除了the issue I am already having之外,我还在I saw a video on it之后安装了HBase(尚未安装)之前,还安装了Zookeeper。在安装它时,我遇到了许
我正在将 XSLT 与 regexp:match exslt 函数一起使用。上述函数采用 JavaScript Regex 模式。因此,我尝试匹配一组数字 1 到 3 OR 5 到 7 OR 9 到
我想知道为什么这段代码会给出消息:SyntaxError:意外的标记其他。 var compare = function(choice1,choice2){ if(choice1===choice2)
我尝试使用复选框和 JQuery 过滤日历上的事件, $(document).ready(function () { $('.scrollable-menu :checkbox').click(f
假设我们有一个用户想要一个名为:“test/lasdhjal.txt”,无论如何。现在,如果我将其放入新的文件(输入)中;对象里面,它会认为 test/是一个文件夹,而它是名称的一部分。我能做什么呢?
问题是 stash 的更改不会留在我 stash 它们的分支中。其他分支存储将被覆盖示例: 我愿意: git checkout iss4 // made some changes gi
我是一个 java 新手,并且在 StackOverflow 错误/在类之间访问文件的能力方面遇到了一个非常令人困惑的问题。我知道根本原因可能是我进行了一些递归调用,但修复它的语法却让我无法理解。我认
public X createData(int n) { int[] values = new int[n]; Random rand = new Random(); for
我是一名优秀的程序员,十分优秀!