next_permutation全排列算法
2013-04-20 09:24
204 查看
C++ STL中的一个可以方便的生成全排列的算法:
#include <algorithm>
bool next_permutation( iterator start, iterator end );
使用举例:
#include <iostream>
#include <algorithm>
#include <string>
using namespace std;
int main()
{
string str;
cin >> str;
sort(str.begin(), str.end());//必须进行这一步才可以
cout << str << endl;
while (next_permutation(str.begin(), str.end()))
cout << str << endl;
return 0;
}
摘自百度知道……
#include <algorithm>
bool next_permutation( iterator start, iterator end );
使用举例:
#include <iostream>
#include <algorithm>
#include <string>
using namespace std;
int main()
{
string str;
cin >> str;
sort(str.begin(), str.end());//必须进行这一步才可以
cout << str << endl;
while (next_permutation(str.begin(), str.end()))
cout << str << endl;
return 0;
}
qsort(数组名,数组长度,数组中每个元素大小,compare); compare函数的写法决定了排序是升序还是降序。需要#include<stdlib.h> 例如: int compare(const void*a,const void*b){return *(*int)a-*(int*)b;} 示例:qsort(a,10,sizeof(int),compare) //假设已定义了整型数组a[10] 升序排序的写法,如果是:return *(*int)b-*(int*)a 就是降序,不论是什么类型的数组,该函数的形式都是这样的 sort(数组名,数组末地址,compare) //若不写compare则默认升序排列,需要#include<algorithm> 例如: sort(a,a+10); //将数组a以升序排序,假设先前定义了a[10]并输入了数据
摘自百度知道……
相关文章推荐
- next_permutation(全排列算法)
- next_permutation(全排列算法)
- next_permutation(全排列算法)
- next_permutation(全排列算法)
- next_permutation(全排列算法)
- next_permutation(全排列算法)
- next_permutation(全排列算法)
- next_permutation (全排列算法)的使用
- next_permutation(全排列算法)
- 排列2 next_permutation(全排列算法)
- next_permutation(全排列算法)
- next_permutation(全排列算法)
- 用next_permutation()生成r-组合数,兼发现VC7的一个bug
- 全排列生成算法:next_permutation
- hdu 1027 hdu 1716 (next_permutation的使用)
- [STL] next_permutation 的原理和使用
- [POJ1833] 排列(STL之next_permutation)
- HDU 1027 Ignatius and the Princess II(next_permutation()的应用)
- 全排列next_permutation()的用法
- next_permutation的简单用法及例题