鱼C论坛

 找回密码
 立即注册
查看: 1462|回复: 0

C++ 枚举算法

[复制链接]
发表于 2020-2-2 21:54:40 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
枚举算法


枚举算法就是按照问题本身的性质,一一列举出该问题所有的解,并根据问题的条件对各解进行逐个检验,从中挑选出符合条件的解,舍弃不符合条件的解。

枚举算法的思路

1.png

枚举算法举例

例 1

求 1 ~ 1000 中,能被 7 和 11 同时整除的数。

输出为两行,第一行为所有满足题目要求的数,以空格分割;第二行为满足题目要求的数的个数。

程序如下:

  1. #include <iostream>
  2. using namespace std;

  3. int main()
  4. {
  5.     int i, count = 0;
  6.     for (i = 1; i <= 1000; i++)
  7.     {
  8.         if (i % 7 == 0 && i % 11 == 0)
  9.         {
  10.             cout << i << " ";
  11.             count++;
  12.         }
  13.     }
  14.     cout << endl;
  15.     cout << count;
  16.     return 0;
  17. }
复制代码


执行结果:

  1. 77 154 231 308 385 462 539 616 693 770 847 924
  2. 12
复制代码


例 2

求 100 ~ 999 中的所有水仙花数。

第一行为所有满足题目要求的数,以空格分割;第二行为所有满足题目要求的数的个数。

程序如下:

  1. // 求水仙花数

  2. #include <iostream>
  3. using namespace std;

  4. int main()
  5. {
  6.     int i, count = 0, a, b, c;
  7.     for (i = 100; i < 1000; i++)
  8.     {
  9.         a = i / 100;
  10.         b = i % 100 / 10;
  11.         c = i % 10;
  12.         if ((a * a * a + b * b * b + c * c * c) == i)
  13.         {
  14.             cout << i << " ";
  15.             count++;
  16.         }
  17.     }
  18.     cout << endl;
  19.     cout << count;
  20.     return 0;
  21. }
复制代码


执行结果:

  1. 153 370 371 407
  2. 4
复制代码


枚举算法总结

优点:比较直观,容易理解;正确性容易证明。

不足:效率低

枚举算法是最简单、最直白、最粗暴的方法,它根据所需解决问题的条件,把该问题所有的解全部列举出来,并逐个检验出问题真正的解。

枚举算法又被称为穷举算法。

本帖被以下淘专辑推荐:

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-5-28 04:00

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表