- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
所以我想创建一个子集,通过代码运行该子集,然后创建一个新的子集。我正在为集合和子集使用 vector 。到目前为止,我有 3 个嵌套的 for 循环,但我无法找出我需要的变量。
这是我想做的。 set = {0, 1, 2, 3, 4, 5} 值匹配索引只是为了简化这个例子。我现在想要 subset = {} -> {0} -> {1} -> ... -> {0,1} -> {0,2} -> ... -> {0,5} -> {0,1,2} -> ... -> {0,4,5}。我在用变量表示条件时遇到问题。
基本上我想要第一个 for 循环来增加子集的大小。从 0 到 set.size() (这很简单)。在该循环中,我希望有一个迭代器对应于子集元素中的索引。我将此迭代器初始化为 subset.size(),以便我们首先处理最后一个元素,然后处理子集中的第一个元素。然后是第三个 for 循环,我想在集合中的可能值之间进行迭代。假设我们当前的子集 = {0,1,2} 我如何让我的程序知道将值“2”放入子集的最后一个元素中,然后是 1,然后是 0?
我认为它会涉及到与 set.size()-1 和 subset.size()-1 的区别?但我不太确定如何。所以然后我想遍历直到 {0,1,5} 然后是 {0,4,5} 但是我又一次不确定如何告诉程序停止在 4,而不是 5。我再次认为这个是有区别的东西,但我不太明白。
回顾一下:
for loop to iterate through subset size
for loop to iterate through subset "working" element, starting from back
for loop to iterate through that index of subset,
starting from the correct corresponding set value to ending
at the correct corresponding set value
这样子集从 {} -> {0} -> {1} ->...-> {0,1} -> {4,5} -> {1,2,3} -> ... -> {1,4,5} 我实际上不需要 subset = {1,2,3,4,5} 但如果我不能在此之前停止,它不会伤害我的代码。我再次希望将起点和终点表示为变量以使内部循环工作,但我无法弄清楚。非常感谢任何能帮助我的人。
最佳答案
这就是我大致的处理方式。
//handle null subset
for ( int size = 1; size < n; i++ ) {
int indices[size];
for ( int i = 0; i < size; i++ ) indices[i] = i;
while ( indices[0] <= n - size ) {
int i;
for ( i = 1; indices[size - i] == n - i; i-- );
indices[i]++;
for ( i = i + 1; i < size; i++ ) indices[i] = indices[i-1] + 1;
//print out elems using the indices in `indices`
}
//done with all subsets of size `size`
}
外循环应该很容易解释。包括 0 似乎会使一些内部逻辑变得烦人,所以我从大小为 1 的子集开始。
indices
保存应包含在当前子集中的元素的索引。它以索引 0
-size-1
开始。
while
的条件不是很明显。它生成的最后一个有效子集包含最后一个 size
元素,因此如果第一个索引超过 n - size
,我们就做得太过了。
while 循环内部只是递增子集。它寻找最后一个可以递增并仍然给出有效子集的元素,递增它,然后将所有后续元素重置为尽可能小。然后你以某种方式打印出来。
而且这应该接近于满足您的需求。让我知道它是否需要澄清或更正。
关于c++ - 使用 vector 迭代地创建集合的子集,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28553470/
我有这个析构函数,它在运行时产生错误“vector 迭代器不可取消引用”。 gridMatrix 是一个 std::vector * > * > * > * > 我添加了 typename 和 typ
我有一个 vector 的 vector ,比方说 std::vector > my2dArray; 现在我想要一个 vector ,其中包含 my2dArray 中 vector 的大小。手动这看起
假设我有一些 vector :v1、v2、v3 假设我还有一个 vector 来保存这些 vList = {v1, v2, v3} 如果我同步了 (vList),这是否意味着 v1、v2 和 v3 也
我正在创建一个 char 的二维 vector 数组作为类变量,但我在将 vector 添加到 vector 数组中时遇到了麻烦。 我正在使用 C++ 11 标准运行 gcc。 我尝试使用 vecto
如何修改 Vec基于 Vec 中某项的信息没有对向量的不可变和可变引用? 我已尝试创建一个最小示例来演示我的特定问题。在我的真实代码中,Builder struct 已经是其他答案提出的中间结构。具体
这个问题在这里已经有了答案: What is the idiomatic Rust way to copy/clone a vector in a parameterized function? (
在我的程序中,我有一个整数 vector 的 vector 。现在我想从 vector 的 vector 中取出一个 vector 并在另一个 vector 容器中对其进行操作,但是我得到了错误...
我得到一个vector>数据由 OpenCV 提供。由于某些原因(例如偏移/缩放),我需要转换数据 Point至Point2f 。我怎样才能做到这一点? 例如: std::vector > conto
我有一个函数,该函数应使用来自字符串类型的给定 vector vector 中的某些元素初始化来自字符串类型的空 vector vector 。我的语法看起来像这样 std::vector> extr
我得到一个vector>数据由 OpenCV 提供。由于某些原因(例如偏移/缩放),我需要转换数据 Point至Point2f 。我怎样才能做到这一点? 例如: std::vector > conto
这里有很多类似的问题,但我没有真正找到任何可以特别回答我的问题的问题。 我有一个 vector 的 vector 作为类的属性。另一个属性是 bucket_count。我想将 vector 的 vec
如果我像这样创建一个 vector 的 vector : std::vector> myVectorOfVectors; 然后用一些东西填充它: std::vector myVector1; myVe
我正在用 C++ 编写自定义 vector 类。我对这样的代码有疑问: vector vec; vec.push_back(one); vec.push_back(two);
这是我发布的问题 c++ program for reading an unknown size csv file (filled only with floats) with constant (b
vector> a; for (int i=0;i v(i+1); iota(v.begin(),v.end(),1); a.push_back(v); } a.erase(a.beg
也许已经晚了,但我不明白为什么我会得到一个超出此代码范围的 vector 下标: int m = 3; int n = 2; std::vector> path(m, std::vector(n, 0
这个问题真的很奇怪,我似乎找不到任何导致它的原因。 所以这里有一个赋值运算符重载函数,鸟类和哺乳动物都是 vector 。 (下面是类) const Register& Register::opera
我怎么去 std::vector> 只是 std::vector> ?有真正有效的方法吗? 最佳答案 我会做这样的事情: #include #include int main() { //
我正在尝试将这些 vector 中的一些数据写入文本文件。当我运行代码时,它返回运行时错误。 Category、Product、Cart、Customer和Address都是struct 包含每个 g
显然它会因您使用的编译器而异,但我很好奇执行 vector> 时的性能问题与 vector*> ,尤其是在 C++ 中。具体来说: 假设您的外部 vector 已满,您想要开始将元素插入到第一个内部
我是一名优秀的程序员,十分优秀!