是否可以使用std :: next_permutation()来置换我创建的类的向量元素?
next_permutation()中的compare参数如何工作?
答案 0 :(得分:9)
是否可以使用std :: next_permutation()来置换我创建的类的向量元素?
是!
试试这个
#include<iostream>
#include<vector>
#include<algorithm>
int main()
{
typedef std::vector<int> V; //<or_any_class>
V v;
for(int i=1;i<=5;++i)
v.push_back(i*10);
do{
std::cout<<v[0]<<" "<<v[1]<<" "<<v[2]<<" "<<v[3]<<" "<<v[4]<<std::endl;;
}
while(std::next_permutation(v.begin(),v.end()));
}
next_permutation()中的compare参数如何工作?
This可能有帮助
答案 1 :(得分:4)
是的,最简单的方法是覆盖运算符&lt;在你的班级中,你不需要担心comp。
comp参数是一个函数指针,它将两个迭代器传递给向量,并根据你想要它们的排序方式返回true或false。
编辑:未经测试,但值得:
class myclass
{
public:
myclass() : m_a( 0 ){}
void operator = ( int a ) { m_a = a; }
private:
friend bool operator<( const myclass& lhs, const myclass& rhs ) { return lhs.m_a < rhs.m_a; }
int m_a;
};
int _tmain(int argc, _TCHAR* argv[])
{
myclass c;
std::vector<myclass> vec;
for( int i = 0; i < 10; ++i )
{
c = i;
vec.push_back( c );
}
//these two should perform the same given the same input vector
std::next_permutation( vec.begin(), vec.end() );
std::next_permutation( vec.begin(), vec.end(), &operator< );
return 0;
}
答案 2 :(得分:3)
当然可以;你只需要将迭代器传递给第一个元素,将一个迭代器传递给后一个元素,就像STL算法一样。
它是一个用于比较矢量元素(或一般容器)的函子;它应该表现为任何&lt; operator会这样做:如果第一个元素小于第二个元素,则返回true,否则返回false,从而在对象之间建立顺序关系。请注意,作为所有比较运算符,它必须遵循一些规则(here在稍微不同的上下文中解释,但它们始终相同)。
顺便说一句,如果你定义一个&lt;你的类的运算符你可以简单地使用第一个重载(只有迭代器作为参数),并避免创建一个单独的函子。