C++011-C++循环+枚举

news2024/11/23 19:29:55

文章目录

  • C++011-C++循环+枚举
    • 枚举
      • 枚举思想
      • 枚举举例
      • 题目描述 统计因数
      • 题目描述 质数判定
        • 错误方法一:
        • 优化方法1: 用break实现优化
        • 优化方法2: sqrt(n)
      • 题目描述 水仙花数
      • 题目描述 7744问题
        • 实现方法1
        • 优化方法2
      • 题目描述 余数相同问题
      • 题目描述 特殊自然数
      • 总结
      • 作业
    • 在线练习:
    • 总结

C++011-C++循环+枚举

在这里插入图片描述

在线练习:
http://noi.openjudge.cn/
https://www.luogu.com.cn/

枚举

在数学和计算机科学理论中,一个集的枚举是列出某些有穷序列集的所有成员的程序,或者是一种特定类型对象的计数。这两种类型经常(但不总是)重叠。枚举是一个被命名的整型常数的集合!。
在这里插入图片描述

在这里插入图片描述

枚举思想

枚举:列出某些有穷序列集的所有成员,或者对一种特定类型对象的计数

①有限的范围
②所有的成员
③特定的类型

根据枚举的定义:
在这里插入图片描述

数图形的时候∶

只在一个大图中数。——有限的范围
要求在各种几何形状数图形——所有的成员
从中统计矩形的数量——特定的类型

有同学可能会问∶所有的成员为什么是各种几何图形,而不是所有的矩形呢?
归根结底就是枚举时宁可多,但不能漏!

如果能确定某个问题的答案在一定的范围内,那么我们就列举这个范围内的所有成员(或者确定能包括答案的特定成员),再通过筛选和判断锁定特定类型,最后得出答案。

定范围
列成员
选类型
算答案

枚举举例

题目描述 统计因数

题目描述
任意一个自然数N都可以分解质因数,如果写出如下形式:
N = P 1 M 1 ∗ P 2 M 2 ∗ . . . ∗ P n M n N=P_{1}^{M1}*P_{2}^{M2}*...*P_{n}^{Mn} N=P1M1P2M2...PnMn
那么N一共有有 ( M 1 + 1 ) ∗ ( M 2 + 1 ) ∗ . . . ∗ ( M n + 1 ) (M1+1)*(M2+1)*...*(Mn+1) (M1+1)(M2+1)...(Mn+1)个因数,包括1和N本身
例如 36 = 2 2 ∗ 3 2 36=2^{2}*3^{2} 36=2232,那么36一共有(2+1)*(2+1)=9个因数,包括1和36.
解题思路
用枚举思想来验证:

  1. 定范围:36的因数一定是1到36之间的正整数
  2. 列成员 1 2 3 4 …36
  3. 选类型+算答案 1.2.3.4.6.9.12.18.36,共9个。
#include <iostream>
//#include<bits/stdc++.h>

using namespace std;

int main()
{
    int s=0;
    for(int i =1; i<=36; i++ )
    {
        if(36%i==0) {
                cout<<i<<" ";
                s++;
        }
    }
    cout<<endl<<s;

    return 0;
}

输出为:
在这里插入图片描述

题目描述 质数判定

题目描述
如果一个数n,除了1和他本身,没有其他的因数,这个数就是质数
方法一:枚举所有可能是n的因数的数,统计有多少个因数,如果只有两个,那么这个数是质数,否则不是。
方法二:枚举2到n-1之间的自然数,如果存在n的因数,那么这个数可定不是质数,如果不存在n的因数,那么这个数是质数

那么我们怎么“定范围”?——按照方法一的话,范围就是1到这个数本身。
怎么列成员——列举所有的自然数
怎么选类型——判断是否能整除给定数字
怎么算答案——找到一个整除的,则统计因数增加一次,最后看有多少个因数。如果只有2个,那就是质数,否则是合数。

错误方法一:

#include <iostream>
//#include<bits/stdc++.h>

using namespace std;

int main()
{
    int n=0;
    cin>>n;
    int flag = 1;//1表示是质数,0表示不是质数
    for(int i =2; i<=n-1; i++ )
    {
        if(n%i==0) {
                flag = 0;
        }
        else{
            flag = 1;
        }
    }
    if(flag==1) cout<<"是质数";
    else cout<<"不是质数";

    return 0;
}

优化方法1: 用break实现优化

#include <iostream>
//#include<bits/stdc++.h>

using namespace std;

int main()
{
    int n=0;
    cin>>n;
    int flag = 1;//1表示是质数,0表示不是质数
    for(int i =2; i<=n-1; i++ )
    {
        if(n%i==0) {
                flag = 0;
                break;
        }
    }
    if(flag==1) cout<<"是质数";
    else cout<<"不是质数";

    return 0;
}

质数判定的进一步优化∶平方根优化。其实我们还可以进一步缩小枚举的范围。过去我们枚举的范围是2到n-1,其实并不必要,只要枚举2-sqrt(n)即可。这是因为,如果n能够分解成两个数的乘积,那么其中一个必须≤sqrt(n),另外一个≥sqrt(n);这里,sqrt(n)表示n的平方根。
测试2147483647

优化方法2: sqrt(n)

#include <iostream>
#include<cmath>
//#include<bits/stdc++.h>

using namespace std;

int main()
{
    int n=0;
    cin>>n;
    int flag = 1;//1表示是质数,0表示不是质数
    int t = sqrt(n);
    for(int i =2; i<=t; i++ )
    {
        if(n%i==0) {
                flag = 0;
                break;
        }
    }
    if(flag==1) cout<<"是质数";
    else cout<<"不是质数";

    return 0;
}

题目描述 水仙花数

题目描述
水仙花数是一种自幂数,有如下两个特点:
1.是三位数
2.各个数位上的数字的三次方和等于他本身,六日
153= 111 + 555 + 333
输入

输出
所有的水仙花数,每一个数字占一行。
样例输入

样例输出
153

解题思路

定范围:所有的三位数 100-999
列成员:100-999之间所有的自然数
选类型:符合各个数位上数字的三次方和等于本身的才是特点的类型
算答案:找到特点类型数字马上输出
在这里插入图片描述

#include <iostream>
//#include<bits/stdc++.h>

using namespace std;

int main()
{

    for(int i =100; i<=999; i++ )
    {
        int a=i/100,b=i/10%10,c=i%10;
        if(a*a*a+b*b*b+c*c*c==i) cout<<i<<endl;

    }
    return 0;
}

输出入下:
在这里插入图片描述

题目描述 7744问题

题目描述
列出所有满足下列条件的数字
1.是四位数
2.是完全平方数
3.前2位数字相同,后2位数字也相同
输入

输出
每行一个符合条件的数字
样例输入

样例输出
7744

实现方法1

定范围:所有的四位数 1000-9999
列成员:100-9999之间所有的自然数
选类型:
符合完全平方数,即sqrt(i) = (int)sqrt(i);
且前2位数字相同,后两位数字相同
int a = i/1000,b=i/100%10,c=i/10%10,d=i%10;
if(a==b && c==d)
算答案:找到特点类型数字马上输出

#include <iostream>
#include<cmath>
//#include<bits/stdc++.h>

using namespace std;

int main()
{

    for(int i =1000; i<=9999; i++ )
    {
        if(sqrt(i)==(int)sqrt(i))
        {
            int a=i/1000,b=i/100%10,c=i/10%10,d=i%10;
            if(a==b&&c==d) cout<<i<<endl;

        }

    }
    return 0;
}

优化方法2

【7744问题-浮点数运算有误差,如果想避开浮点数应该如何做?】

列成员
用循环变量直接列举1000~9999的完全平方数;
枚举i*i的值,而不是仅枚举i,我们需要根据此需要确定i的范围
定范围
由10000>9999> =i*i>=1000推知:99> =i>=32 ;
for(int i=32;i<=99;i++){
int t=i*i;
}
选类型
前两位相同,后两位相同
把四个数位上数字分别取出再比较:
int a=t/1000,b=t/100%10,c=t/10%10,d =t%10;. if(a= =b&&c==d)则前两位相同,后两位相同;
算答案:
符合条件的t是答案

#include <iostream>
//#include<bits/stdc++.h>

using namespace std;

int main()
{

    for(int i =32; i<=99; i++ )
    {
        int t=i*i;
        int a=t/1000,b=t/100%10,c=t/10%10,d=t%10;
        if(a==b&&c==d) cout<<t<<endl;
    }
    return 0;
}

题目描述 余数相同问题

题目描述
已知三个正整数a,b,c。
现有一个大于1的整数x,将其作为除数分别除a, b,c,得到的余数相同。请问满足上述条件的x的最小值是多少?
数据保证x有解。
输入
一行,三个不大于1000000的正整数a, b,c,两个整数之间用一个空格隔开。
输出
一个整数,即满足条件的x的最小值。
样例输入
300 262 205
样例输出
19

定范围:
数据保证有解,只需要求x最小的值。上限不需确定,找到解后,break就可。
保险起见,余数不会大于被除数和除数,范围可以设定位2到三个数字中的任意一个。
列成员:
从小到大列举范围内的整数
for(int i=2;i<=a;i++){
}
选类型:
分别除以a,b,c 得到的余数相同 a%i==b%i&&b%i==c%i
算答案:
找到特点类型数字i马上输出

#include <iostream>
//#include<bits/stdc++.h>

using namespace std;

int main()
{
    int a,b,c;
    cin>>a>>b>>c;
    for(int i=2;i<=a;i++){
        if(a%i==b%i && b%i==c%i){
            cout<<i;
            break;
        }
    }
    return 0;
}

题目描述 特殊自然数

题目描述
一个十进制自然数,他的七进制和九进制表示都是三位数,且七进制和九进制数码的表示顺序正好相反,编程求此自然数,并输出显示。
输入

输出
三行:
第一行是此自然数的十进制表示;
第二行是此自然数的七进制表示;
第三行是此自然数的九进制表示。
样例输入

样例输出

预备知识

十进制与N进制的互相转换:
N进制:位权为N的数制。
十进制: ( 1234 ) 10 = 1 ∗ 1 0 3 + 2 ∗ 1 0 2 + 3 ∗ 1 0 1 + 4 ∗ 1 0 0 (1234)_{10}=1*10^{3}+2*10^{2}+3*10^{1}+4*10^{0} (1234)10=1103+2102+3101+4100
从低位到高位分别为第0位,第1位,第2位…
七进制:
( 1234 ) 7 = 1 ∗ 7 3 + 2 ∗ 7 2 + 3 ∗ 7 1 + 4 ∗ 7 0 (1234)_{7}=1*7^{3}+2*7^{2}+3*7^{1}+4*7^{0} (1234)7=173+272+371+470
把N进制的数字按照 位权 展开,计算得到的数字就是十进制的数字了。
N进制下的数位拆分:
十进制下,M%10=十进制表示下的最末尾。
N进制下,M%N=N进制表示下的最末尾。
( 1234 ) 7 = 1 ∗ 7 3 + 2 ∗ 7 2 + 3 ∗ 7 1 + 4 ∗ 7 0 (1234)_{7}=1*7^{3}+2*7^{2}+3*7^{1}+4*7^{0} (1234)7=173+272+371+470
( 1234 ) 7 % 7 = ( 1 ∗ 7 3 + 2 ∗ 7 2 + 3 ∗ 7 1 + 4 ∗ 7 0 ) % 7 = 4 (1234)_{7}\%7=(1*7^{3}+2*7^{2}+3*7^{1}+4*7^{0})\%7=4 (1234)7%7=(173+272+371+470)%7=4余数定理

在这里插入图片描述

定范围:
在十进制下定范围,七进制和九进制下是三位数
七进制下的最大数位666,最小的三位数位100,转换为十进制得到范围为 ( 100 ) 7 = 49 , ( 666 ) 7 = 6 ∗ 49 + 6 ∗ 7 + 6 ∗ 1 = 342 (100)_{7}=49,(666)_{7}=6*49+6*7+6*1=342 (100)7=49,(666)7=649+67+61=342范围i为[49,342]
九进制下的最大数位888,最小的三位数位100,转换为十进制得到范围为 ( 100 ) 9 = 81 , ( 888 ) 9 = 8 ∗ 81 + 8 ∗ 9 + 8 ∗ 1 = 728 (100)_{9}=81,(888)_{9}=8*81+8*9+8*1=728 (100)9=81,(888)9=881+89+81=728范围i为[81,728]
取公共部分,这个数在十进制表示下,应属于[81,342]
列成员:
列举从81-342范围内的整数
for(int i=81;i<=342;i++){
}
选类型:
七进制和九进制下数字正好相反,设七进制下ABC,九进制下abc
int A=i/7/7%7,B=i/7%7,C=i%7;
int a=i/9/9%9,b=i/9%9,C=i%9;
如果A==c&&B==b&&C==c,那么i符合题意
算答案:
若符合提议,则输出答案,依次输出i,ABC,abc每个答案占据一行

#include <iostream>
//#include<bits/stdc++.h>

using namespace std;

int main()
{
    for(int i=81;i<=342;i++){
        int A,B,C,a,b,c;
        A=i/7/7%7,B=i/7%7,C=i%7;
	    a=i/9/9%9,b=i/9%9,c=i%9;
        if(A==c&&B==b&&C==a){
            cout<<i<<endl;
            cout<<A<<B<<C<<endl;
            cout<<a<<b<<c<<endl;
        }
    }
    return 0;
}

输出为:
在这里插入图片描述

总结

枚举思想
枚举的一般解题步骤
运用枚举的思想解决因数统计、质数判断等问题质数判断的平方根优化
break和continue
N进制的定义

作业

在这里插入图片描述

在这里插入图片描述

在线练习:

http://noi.openjudge.cn/

总结

本系列为C++学习系列,会介绍C++基础语法,基础算法与数据结构的相关内容。本文为C++循环结构的中的枚举案例,包括相关案例练习。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/360214.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

《第一行代码》 第六章:数据库与存储方案

一&#xff0c;持久化技术简介 也就是数据存储在内存中&#xff0c;会丢失。需要存储在存储设备中。而持久化技术&#xff0c;就是提供了手段&#xff0c;让数据再试瞬时状态和持久状态之间转换。 安卓开发提供了三种数据的持久化技术&#xff1a; 二&#xff0c;文件存储 …

【HDFS】FsDatasetImpl#getReplicaVisibleLength

调用点 DataNode.getReplicaVisibleLength(ExtendedBlock) (org.apache.hadoop.hdfs.server.datanode) // ClientDataNodeProtocolBlockChecksumComputer in BlockChecksumHelper.BlockChecksumComputer(DataNode, ExtendedBlock, BlockChecksumOptions) (org.apache.hadoop.hd…

ros中时间的概念:ros::Time、ros::Duration、定时器ros::Timerros::Rate、ros::WallTime

1. ros时间格式说明 有时刻和持续时长(可以是负数)&#xff0c;分为秒和纳秒&#xff0c;换算关系&#xff1a;1sec1e9nsec。Time指的是某个时刻&#xff0c;而Duration指的是某个时段。 int32 sec int32 nsec 2. ros::Time::now() 记录当前时刻 3. ros::Duration 代表持续的…

Linux 输出重定向 “>”、“>>”、“freopen”

有时候&#xff0c;我们编码时会使用printf或fprintf去打印输出调试信息或者报错信息&#xff0c;但正常这样去打印&#xff0c;只会显示在终端&#xff0c;如果终端关闭了&#xff0c;或者系统宕机了等&#xff0c;这些输出信息就没有了&#xff0c;为了将这些重要的信息保存下…

java诊断与调优常用命令jmap、jstack、jstat使用实战

java应用运行过程中难免会出现问题&#xff0c;特别是在生产环境&#xff0c;发生异常或宕机情况&#xff0c;需要诊断与分析&#xff0c;定位原因&#xff0c;进行优化&#xff0c;避免下次再次出现问题。 虽然现在有很多可视化工具&#xff0c;使用起来比命令行更方便&#x…

开学季好用电容笔有哪些?好用实惠的电容笔推荐

随着科学技术的快速发展&#xff0c;ipad的影响力越来越大&#xff0c;而且ipad的用户也越来越多&#xff0c;如果要提高ipad的功能&#xff0c;让ipad更加有趣&#xff0c;那么就需要一款非常适合自己&#xff0c;并且非常实用的电容笔。那么&#xff0c;究竟该选择哪个品牌的…

SpringBoot整合分布式锁redisson

1、导入maven坐标<!-- 用redisson作为所有分布式锁&#xff0c;分布式对象等功能框架--><dependency><groupId>org.redisson</groupId><artifactId>redisson</artifactId><version>3.12.5</version></dependency>2、red…

蓝牙 - BLE中的连接和扫描参数设定

连接参数 / Connection Parameters 连接参数由发起设备与连接请求一起发送&#xff0c;当连接建立后&#xff0c;任何一个设备都可以修改。这些参数如下&#xff1a; 连接间隔 / Connection Interval 在低功耗蓝牙连接中&#xff0c;使用了跳频方案。两台设备发送各自数据和接…

day48【代码随想录】动态规划之最长递增子序列、最长连续递增序列、最长重复子数组

文章目录前言一、最长递增子序列&#xff08;力扣300&#xff09;二、最长连续递增序列&#xff08;力扣674&#xff09;三、最长重复子数组&#xff08;力扣718&#xff09;前言 1、最长递增子序列 2、最长连续递增序列 3、最长重复子数组 一、最长递增子序列&#xff08;力扣…

rocketmq延时消息自定义配置;topic下tag使用

概述 使用的是开源版本的rocketmq4.9.4 rocketmq也是支持延时消息的。 rocketmq一般是4个部分&#xff1a; nameserver&#xff1a;保存路由信息broker&#xff1a;保存消息生产者&#xff1a;生产消息消费者&#xff1a;消费消息 延时消息的处理是在其中的broker中。 但是…

我为什么放弃WinUI3

基于WinUI3开发HiNote已经有一个多月的时间了&#xff0c;算是做出来一个简单能用的C端软件。 基于个人的经历&#xff0c;说说其中的开发体验。 UI设计语言 无论是否抄袭苹果&#xff0c;WinUI3给人的感觉都是眼前一亮的。简洁美观&#xff0c;现代化&#xff0c;毛玻璃的美…

rk3568网口CAN串口通信速率性能

通信接口性能参数外设接口性能参数测试结果为实验室实测值&#xff0c;可作为设计参考&#xff0c;但因测试环境和器件批次差异&#xff0c;可能会存在一定的误差&#xff0c;且测试结果依赖评估板性能&#xff0c;核心板搭配不同底板性能也可能存在差异&#xff0c;请结合实际…

Redis之分布式锁

随着业务发展的需要&#xff0c;原单体单机部署的系统被演化成分布式集群系统后&#xff0c;由于分布式系统多线程、多进程并且分布在不同机器上&#xff0c;这将使原单机部署情况下的并发控制锁策略失效&#xff0c;单纯的 Java API并不能提供分布式锁的能力。为了解决这个问题…

Java:顶级Java应用程序服务器 — Tomcat、Jetty、GlassFish、WildFly

如果你想编写Java web应用程序&#xff0c;首先需要做出一个艰难的决定&#xff1a;选择运行应用程序的Java应用程序服务器。什么是应用服务器?一般来说&#xff0c;应用程序服务器执行Java应用程序。在操作系统中启动它们&#xff0c;然后将应用程序部署到其中。将应用程序服…

盘点2023年大企业都在用的优秀项目管理软件

行内有句话&#xff1a;每个成功的项目背后肯定有一个成功的项目经理&#xff0c;而每个项目经理背后都少不了一些专业的项目管理工具。要在任何项目中取得成功&#xff0c;对项目进行全面的管理非常关键&#xff0c;包括项目的执行、计划、推进、监控、结果等&#xff0c;有了…

谈谈我对ai发展的看法

最近难得有时间&#xff0c;通过白话&#xff0c;聊聊我对AI的看法&#xff0c;仅代表个人观点首先表明我的观点&#xff1a;人类当前的人工智能成果&#xff0c;仍然停留在一知半解程度。技术的发展是需要长期的积累和进步&#xff0c;目前AI的发展仍处于入门阶段人类的发展必…

ar远程协助可视化云平台提高患者的医疗体验

“专家的指导意见很科学&#xff0c;患者恢复很快&#xff0c;情况稳定就可以转入普通病房了!这种云急救对基层医院来说太及时太必要了!大专家不用奔波&#xff0c;我们又提高了救治能力和效率!”这是来自某市基层主任的心里话。 传统远程协助的局限性 传统远程带来了便捷的线上…

【Java基础】输入与输出

输入与输出 输入 获取用键盘输入常用的两种方法 方法 1&#xff1a;通过 Scanner Scanner input new Scanner(System.in); String s input.nextLine(); input.close();方法 2&#xff1a;通过 BufferedReader BufferedReader input new BufferedReader(new InputStrea…

实验室设计|实验室设计要点SICOLAB

一、实验室设计规划要素1、实验室布局&#xff1a;实验室的布局要符合实验室工作流程&#xff0c;可以将实验室划分为干净区和污染区&#xff0c;以确保实验室的卫生和实验的准确性。2、设备选购&#xff1a;根据实验需要选择适当的设备&#xff0c;并确保设备的质量和性能符合…

LA@ML特征分解@奇异值分解@伪逆

文章目录特征分解几何示意图二次型和生成子空间奇异值分解理论数学风格的描述奇异值分解和特征分解的联系&#x1f60a;&#x1f388;机器学习风格的描述对角矩阵的记法酉矩阵unitary matrix性质Moore-Penrose 伪逆矩阵的逆和线性方程组的解(review)伪逆应用迹运算方阵行列式和…