- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试一个示例程序来了解上一个和下一个排列之间的区别。但是,我的程序似乎无法正常运行。我通过询问数组中元素的数量来启动程序,然后使用简单的 for 循环构建数组
for(i = 0; i < x; i++)
ptr[i] = i;
cout << "Possible permuations using prev_permutation: " << endl;
do{
for(i = 0; i < x; i++)
cout << ptr[i] << " ";
cout << endl;
} while(prev_permutation(ptr, ptr+x));
cout << "Possible permuations using next_permutation: " << endl;
do{
for(i = 0; i < x; i++)
cout << ptr[i] << " ";
cout << endl;
} while(next_permutation(ptr, ptr+x));
当我使用包含 3 个元素 (0, 1, 2) 的样本运行代码时。 prev_permutation 给了我 (0, 1, 2 and that's it)。然后 next_permutation 给我 (2, 1, 0)。但是,当我注释 prev_permutation 部分的代码时,当只有 next_permutation 运行时,我得到了集合 (0, 1, 2) 的 6 种不同排列。我似乎无法理解发生了什么。
最佳答案
prev_permutation
和 next_permutation
按字典顺序(“字母顺序”)生成所有排列,它们返回 false
一旦循环完成(即如果在第一个排列上调用 prev_permutation
之后或在最后一个排列上调用 next_permutation
之后)。
发生的事情是,您准备了按字典顺序排列的第一个排列的数组,然后调用 prev_permutation
.然而这是第一次,所以prev_permutation
将数组设置为最后一个排列并返回 false
, 所以你退出循环。
现在您输入 next_permutation
循环,但数组的当前内容是字典顺序的最后一个排列,所以 next_permutation
将设置第一个并返回 false。
如果删除 prev_permutation
然而,部分是 next_permutation
的循环将从第一个开始,因此它将在返回之前正确生成所有 6 个排列 false
.
考虑到按顺序列出的所有排列并将当前配置作为此列表中的指针,您可以想象效果:
0-1-2 << you start here
0-2-1
1-0-2
1-2-0
2-0-1
2-1-0
打电话时 next_permutation
调用prev_permutation
时,你正在向下移动你在向上移动。当超出列表时,两个函数都会将指针移动到另一端并返回 false
通知您这个事实。
如果您以 prev
开头你移动到2-1-0
函数返回 false
, 然后你打电话 next
函数移动到0-1-2
并返回 false
再次。
例如使用 0
代替, 1
和 2
两个零和三个一的排列字典顺序是:
0-0-1-1-1
0-1-0-1-1
0-1-1-0-1
0-1-1-1-0
1-0-0-1-1
1-0-1-0-1
1-0-1-1-0
1-1-0-0-1
1-1-0-1-0
1-1-1-0-0
因此,要枚举所有这些,您需要从 0-0-1-1-1
开始并使用 next_permutation
或者你需要从1-1-1-0-0
开始并使用 prev_permutation
.
在这种情况下调用 next_permutation
在最后一个1-1-1-0-0
会改成第一个0-0-1-1-1
并将返回 false
;以类似的方式调用 prev_permutation
在 0-0-1-1-1
将更改为 1-1-1-0-0
并将返回 false
因为翻转。
关于c++ - Prev_permutation 与 Next_permutation 难度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12230763/
排列就是一次对对象序列或值序列的重新排列。例如,“ABC”中字符可能的排列是: "ABC", "ACB", "BAC", "BCA", "CAB", "CBA" 三个不同的字符有 6 种排列,这个数字
给定一个结构(例如): struct permutation_object { int index; string content; }; 以及这些结构的 vector : vecto
有什么方法可以通过在 C++ 中使用 next_permutation 来打印所有排列,而忽略已经以相反顺序出现的排列。例如,在它打印{1, 2, 3, 4} 之后,它不应该打印{4, 3, 2, 1
如果我有: bool shuffle(string s){ return next_permutation(s.begin(), s.end()); } int main(int argc,
我在对空终止字符数组使用 next_permutation 时遇到问题。当我在 do while 语句中登录时,它只给我开始的 charArray 的第一个字符,而不是给我所有可能排列的第一个字符。这
我想知道是否可以使用 OpenMP 并行化此代码。 OpenMP 会让代码运行得更快吗?有没有更好的方法来实现这一点? vector t; // already initialized do{
我正在尝试排列井字棋盘。所以我有以下代码: // 5 turns for x if x goes first std::string moves = "xxxxxoooo"; do { std
从一个范围内对象的可能随机排序开始是否更有效,使用 next_permutation 遍历所有更大的排列,然后降级,再次从原始排序开始,使用 prev_permutation 到达最后一个。 或者,在
我试图找到给定字符列表的所有排列,在本例中为“eta” std::string s="eta"; do { std::cout<
我正在为 next_permutation 函数使用自定义比较器函数,但我不明白为什么会出现错误: Expression: invalid operator 0)) || ((i > 0) && (j
我如何在 while 循环之外使用排列数字来进行比较。因为我已经检查过,while 外部的 vector 与之前定义的相同。 void display(vector vec){ for (in
使用这段代码时: for(int i=0; i
我有以下程序使用函数 next_permutation() 和输出: 8 int main () 9 { 10 int myints[] = {1, 2, 3}; 11 12 co
我正在尝试使用 OpenMP 并行化我自己的旅行商问题的 C++ 实现。 我有一个函数来计算道路成本 cost() 和 vector [0,1,2,...,N],其中 N 是道路的节点数。 在 mai
我正在尝试解决输入两个不同长度的 vector 并添加它们的标量积的问题。它是来自 https://code.google.com/codejam/contest/32016/dashboard#s=
我想知道是否有一种简单的方法可以知道 parity由 c++ 的 std::next_permutation 根据它们的创建顺序创建的排列的(签名)。 int main() { int cou
我有以下作业: 我们有 N 个作品,工期为:t1, t2, ..., tN,截止日期为 d1, d2, ..., dN。如果工程在截止日期之前没有完成,则相应地给予罚分 b1, b2, ..., bN
有没有办法“重置”std::next_permutation()?假设我想多次检查 vector 的排列。我唯一能找到的是交替地通过 next_permutation 和 prev_permutati
是否有一些等效的库或函数可以为我提供一组值的下一个组合,例如 next_permutation 对我有帮助吗? 最佳答案 组合:来自 Mark Nelson 关于同一主题的文章,我们有 next_co
以下程序缺少一个排列条目。 #include #include #include int main ( int argc, char **argv) { std::vector temp
我是一名优秀的程序员,十分优秀!