关于STL中使用next_permutation, prev_permutation实现排列组合的问题

王朝vc·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

最近一直在看<<C++标准程序库>>这本书,在看到"变序性算法"部分的时候,发现两个函数next_permutation, prev_permutation对于我们平时处理排列组合的问题很有帮助,根据书上的介绍写了两个个测试函数:

void func1()

{

vector<int> v;

INSERT_ELEMENTS(v, 1,3);

PRINT_ELEMENTS( v, "myself: ");

while( next_permutation( v.begin(), v.end() ) )

{

PRINT_ELEMENTS( v, "");

}

}

void func2()

{

vector<int> v;

INSERT_ELEMENTS(v, 1,3);

PRINT_ELEMENTS( v, "myself: ");

while( prev_permutation( v.begin(), v.end() ) )

{

PRINT_ELEMENTS( v, "");

}

}

结果运行的时候发现func1输出的结果是正确的:

myself: 1 2 3

1 3 2

2 1 3

2 3 1

3 1 2

3 2 1

但func2输出的结果却是这样:

myself: 1 2 3

再仔细看看书上的说明,终于发现了出错的原因了:

书上其实写的很清楚的: "如果要走遍所有的排列,你必须先将元素排序"

于是修改func2如下:

void func2()

{

vector<int> v;

INSERT_ELEMENTS(v, 1,3);

PRINT_ELEMENTS( v, "myself: ");

sort(v.begin(), v.end(), greater<int>() ); //增加排序(降序)

while( prev_permutation( v.begin(), v.end() ) )

{

PRINT_ELEMENTS( v, "");

}

}

输出的结果正确了 ^_^

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航