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);
}
全部评论

相关推荐

2025-12-27 22:36
门头沟学院 Java
点赞 评论 收藏
分享
2025-12-27 22:14
门头沟学院 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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