5 3
543 542 541 532 531 521 432 431 421 321
分析:这是一道DFS的题,代码如下:
#include<iostream>
#include<stdio.h>
#include<queue>
#include<string.h>
using namespace std;
int n,r;
int vis[100];
int a[100];
void dfs(int n,int count1,int r)
{
if(count1>r)
return ;
for(int i=n;i>=1;i--)
{
if(!vis[i])
{
a[count1]=i;
vis[i]=1;
if(count1==r)
{
for(int i=1;i<=r;i++)
printf("%d",a[i]);
printf("\n");
}
dfs(i,count1+1,r);
vis[i]=0;
}
}
}
int main()
{
while(cin>>n>>r)
{
memset(vis,0,sizeof(vis));
dfs(n,1,r);
}
}原文:http://blog.csdn.net/qq_qingtian/article/details/45421987