首页 > 代码库 > POJ 1833
POJ 1833
使用STL中的next_permutation(opt1,opt2)函数更容易实现。opt1为数组头地址,opt2为数组长度。排列是按字典序的。
当找到下一个排列时,返回真,否则返回假,此时,把原数组重排一次。
#include <iostream>#include <algorithm>#include <cstdio>using namespace std;int p[1100];int main(){ int T; int n,nt; scanf("%d",&T); while(T--){ scanf("%d%d",&n,&nt); for(int i=0;i<n;i++) scanf("%d",&p[i]); for(int i=0;i<nt;i++){ if(!next_permutation(p,p+n)) sort(p,p+n); } printf("%d",p[0]); for(int i=1;i<n;i++) printf(" %d",p[i]); printf("\n"); } return 0;}
POJ 1833
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。