码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • C/C++ 递归指数型枚举


    个人主页:仍有未知等待探索_C语言疑难,数据结构,小项目-CSDN博客

    专题分栏:算法_仍有未知等待探索的博客-CSDN博客

    目录

    一、前言

    二、递归指数型枚举

    1、题目信息

    题目描述

    输入格式

    输出格式

    样例

    提示

     2、解析

     3、代码


    一、前言

    之前进行枚举的时候,都是进行暴力枚举的策略,将所用可能性都枚举一遍以获得最优解,但是枚举全部元素的效率如同愚公移山,无法应付数据范围稍大的情形。其算法的主要策略是跳过一些无效状态,降低问题的规模。

    二、递归指数型枚举

    1、题目信息

    题目链接:U127142 指数型枚举 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

    题目描述

    从 1~n 这 n 个整数中随机选取任意多个,输出所有可能的选择方案。

    输入格式

    输入一个整数n。

    输出格式

    每行输出一种方案。

    同一行内的数必须升序排列,相邻两个数用恰好1个空格隔开。

    对于没有选任何数的方案,输出空行。

    本题有自定义校验器(SPJ),各行(不同方案)之间的顺序任意。

    样例

    样例输入

    ```
    3
    ```

    样例输出

    ```
    1 2 3
    1 2
    1 3
    1
    2 3
    2
    3
    ```

    提示

    1≤n≤15

     2、解析

    如下图是整个程序的思路,n=3,代表要求 n = 3 的方案数。首先我们要先选第一个数,用一个数组进行存储这位数到底选还是不选。如果选的话,就接着往下一位数进行继续判断,知道要判断的位数大于n,代表结束。然后开始进行回溯。

    下图我只对前一半的运行步骤进行了标号,另一半和这个一样。 

     3、代码

    1. #include
    2. #include
    3. using namespace std;
    4. const int N = 20;
    5. int n;//枚举的位数
    6. int st[N];//存储枚举的位数的信息(某位数是否进行了选择)
    7. void bfs(int x){
    8. //如果x>n的话,说明枚举选择结束,接着就是输出所选的组合
    9. if(x>n){
    10. //选n位数,所以循环n次
    11. for(int i=1;i<=n;i++){
    12. //如果为1,代表该数选上了,i下标其实就是要存储的数
    13. if(st[i]==1){
    14. printf("%d ",i);
    15. }
    16. }
    17. printf("\n");
    18. return;
    19. }
    20. //选x位的数
    21. st[x]=1;//1代表选上了
    22. bfs(x+1);//进行接着往下递归
    23. //其实不写也没事,不过写上的话思路更加的完整
    24. st[x]=0;//回溯,把存储状态的数组进行恢复
    25. //不选x位的数
    26. st[x]=2;//2代表了没选上
    27. bfs(x+1);//进行接着往下递归
    28. //其实不写也没事,不过写上的话思路更加的完整
    29. st[x]=0;//回溯,把存储状态的数组进行恢复
    30. }
    31. int main(){
    32. cin>>n;
    33. bfs(1);
    34. return 0;
    35. }

    谢谢大家的支持!

  • 相关阅读:
    第7章 - 多无人机系统的协同控制 --> 多无人机系统建模
    C# FileSystemWatcher 多文件夹、多文件类型文件监控增加、修改、重命名和删除实例
    【pandas基础】--目录(完结)
    Kotlin Compose 与原生 嵌套使用
    金仓数据库KingbaseES客户端编程接口指南-Perl DBI(3. DBI 类)
    LCR 006.两数之和 II - 输入有序数组
    golang-bufio 缓冲扫描
    IP-guard助力能源企业完善终端防泄密措施,保护机密资料安全
    hook回调函数
    如何计算股票程序化交易系统的收益率?
  • 原文地址:https://blog.csdn.net/qq_73435980/article/details/134549429
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号