Time Limit: 1000MS | Memory Limit: 30000K | |
Total Submissions: 13977 | Accepted: 5710 |
Description
Input
Output
Sample Input
3 3 1 2 3 1 3 1 3 2 1 10 2 1 2 3 4 5 6 7 8 9 10
Sample Output
3 1 2 1 2 3 1 2 3 4 5 6 7 9 8 10
题意很明确,需要注意的两点:1,如果用next_permutation()提交C++过,而G++TLE;2,即使使用了C++提交,printf(),scanf()过,cin,cout则TLE,
第一个问题可以解释,但第二个问题就不太明白了,虽然我知道printf(),scanf()比 cin,cout 效率高,但是一般都是大数据的时候才比较明显,这个题目数据只是1024,差距应该不至于到TLE吧,这个比较困惑
#include<iostream> #include<cstring> #include<cstdio> #include<algorithm> #include<cstdlib> using namespace std; int s[1100]; int cmp( const void *a, const void *b ) { return *(int *)a - *(int *)b; } int main() { int m,N,K; scanf("%d",&m); while(m--) { scanf("%d%d",&N,&K); for(int i=0; i<N; i++) scanf("%d",&s[i]); int cnt=0; int flag=0; while(1) { do { if(flag) cnt++; if(cnt==K) { for(int i=0; i<N; i++) { if(i!=N-1) printf("%d ",s[i]); else printf("%d\n",s[i]);; } break; } flag=1; }while(next_permutation(s,s+N)); if(cnt==K)break; else qsort(s,N,sizeof s[0],cmp); } } return 0; }