50911 题解 递归实现指数型枚举

递归实现指数型枚举

https://ac.nowcoder.com/acm/problem/50911

dfs搜索每一位选什么数

#include<cstdio>
using namespace std;
int n,b[20];
bool a[20];
void dfs(int x,int pre){
    for (int i=1;i<=x;i++) printf("%d ",b[i]); //每次都要输出排列
    puts("");
    if (x==n) return;
    for (int i=pre+1;i<=n;i++) //递增选择
     if (!a[i]) a[i]=1,b[x+1]=i,dfs(x+1,i),a[i]=0;
}
int main(){
    scanf("%d",&n);
    dfs(0,0);
}
全部评论

相关推荐

03-04 07:14
门头沟学院 C++
黑皮白袜臭脚体育生:老板:都给工作机会了还想要工资,哪来这么多好事
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务