【C++】判断能否被 3, 5, 7 整除问题解析与优化

news2024/12/17 0:18:31

在这里插入图片描述

博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳]
本文专栏: C++

文章目录

  • 💯前言
  • 💯题目描述
  • 💯老师代码实现与分析
    • 老师代码逻辑分析
    • 优点
    • 缺点
  • 💯学生代码实现与分析
    • 学生代码逻辑分析
    • 优点
    • 缺点
  • 💯改进与优化
    • 优化代码实现
    • 优化点分析
    • 优化效果
  • 💯题目扩展与思考
  • 💯小结


在这里插入图片描述


💯前言

  • 在计算机科学教育中,基础整数计算问题是一种经典且有效的教学策略。这类问题既能帮助初学者掌握编程的基本语法和逻辑,也为更复杂的算法设计与实现奠定了基础。本文以判断整数是否能被 357 整除的问题为例,详细分析问题背景代码实现及其优化方法,并探讨潜在的扩展应用。
    不仅如此,本问题在条件分支逻辑设计代码结构优化等方面蕴含着丰富的学习价值。通过深入剖析不同实现方式及其优缺点,本文旨在为读者提供系统化的解决思路,同时为更高级的编程问题奠定理论基础实践能力
    C++ 参考手册
    在这里插入图片描述


💯题目描述

判断能否被 3,5,7 整除
在这里插入图片描述

题目:判断能否被 3, 5, 7 整除

给定一个整数 x x x,判断是否能被 3、5、7 整除,并输出以下信息:

  1. 如果能同时被 3、5 和 7 整除,输出 3 5 7
  2. 如果能被其中两个数字整除,按照数字从小到大的顺序输出,例如 3 5
  3. 如果只能被其中一个数字整除,输出对应的数字;
  4. 如果不能被任何一个数字整除,输出 n

输入格式:
输入一行,包含一个整数 x x x

输出格式:
输出一行,按照题目要求给出整数 x x x 是否能被 3、5、7 整除的情况。

输入输出示例:

输入:

105

输出:

3 5 7

数据范围:
1 ≤ x ≤ 200 1 \leq x \leq 200 1x200


💯老师代码实现与分析

老师代码采用多层条件判断逻辑,逐一覆盖所有可能的输出情景,以确保解法的完整性。以下为代码实现:

#include <iostream>
using namespace std;

int main()
{
    int n = 0;
    cin >> n;

    if (n % 3 == 0 && n % 5 == 0 && n % 7 == 0)
        cout << "3 5 7" << endl;
    else if (n % 3 == 0 && n % 5 == 0)
        cout << "3 5" << endl;
    else if (n % 3 == 0 && n % 7 == 0)
        cout << "3 7" << endl;
    else if (n % 5 == 0 && n % 7 == 0)
        cout << "5 7" << endl;
    else if (n % 3 == 0)
        cout << "3" << endl;
    else if (n % 5 == 0)
        cout << "5" << endl;
    else if (n % 7 == 0)
        cout << "7" << endl;
    else
        cout << "n" << endl;

    return 0;
}

在这里插入图片描述


老师代码逻辑分析

  1. 条件覆盖性

    • 每个分支明确对应一种输出情景,从 3 5 7 到单独的 357,以及无法整除时的 n,保证逻辑无遗漏。
  2. 执行顺序直观

    • 多层 if-else if 语句按照条件优先级执行,逻辑清晰易读。

优点

  • 清晰直观:通过显式列举所有条件,逻辑易于理解和调试。
  • 全面性强:覆盖了所有可能的输入情景。

缺点

  • 代码冗长:多层条件判断导致代码显得繁琐。
  • 扩展性较差:若需新增判断条件(如判断能否被 11 整除),需增加多个分支。
  • 重复计算:条件中存在重复计算(如 n % 3),影响性能。

💯学生代码实现与分析

学生代码通过多个独立的 if 条件判断实现,逻辑更加简洁。以下为代码:

#include <iostream>
using namespace std;

int main()
{
    int x;
    cin >> x;

    if (x % 3 == 0)
        cout << 3 << " ";
    if (x % 5 == 0)
        cout << 5 << " ";
    if (x % 7 == 0)
        cout << 7 << " ";
    if (x % 3 != 0 && x % 5 != 0 && x % 7 != 0)
        cout << "n" << endl;

    return 0;
}

在这里插入图片描述


学生代码逻辑分析

  1. 独立性强

    • 每个条件均独立判断,避免嵌套逻辑。
  2. 直接输出

    • 满足条件即输出对应数字,无需考虑优先级。

优点

  • 实现简洁:逻辑结构清晰,易于理解。
  • 可扩展性高:新增条件只需添加对应的 if 语句。

缺点

  • 输出格式问题:数字后可能多出空格,影响输出格式。
  • 重复计算x % 3 等条件可能被多次检查。

💯改进与优化

基于上述实现的优缺点,我们提出以下优化方案,以提升代码效率与可维护性,同时确保输出格式符合要求。


优化代码实现

#include <iostream>
using namespace std;

int main()
{
    int x;
    cin >> x;

    string result = ""; // 用于存储输出结果

    if (x % 3 == 0)
        result += "3 ";
    if (x % 5 == 0)
        result += "5 ";
    if (x % 7 == 0)
        result += "7 ";

    if (result.empty())
        cout << "n" << endl;
    else
        cout << result.substr(0, result.size() - 1) << endl; // 去掉多余空格

    return 0;
}

优化点分析

  1. 字符串拼接简化逻辑

    • 动态拼接结果字符串,避免了多层条件嵌套。
    • 最终输出时去除末尾多余空格,确保格式正确。
  2. 减少重复计算

    • 避免了对同一条件的重复判断,提高运行效率。
  3. 增强可扩展性

    • 新增条件时,只需追加对应的 if 判断。

优化效果

  • 效率提升:减少冗余计算。
  • 格式正确:通过字符串操作保证输出符合要求。
  • 代码简洁:逻辑清晰,易于维护。

💯题目扩展与思考

  1. 扩展整除范围

    • 若需判断是否能被任意一组数字整除(如 2、3、5、7、11),可通过数组存储条件并动态遍历。
  2. 并行计算优化

    • 针对大规模输入数据,可采用多线程实现,提升整体计算效率。
  3. 跨语言实现

    • 尝试在 Python、Java 等语言中实现,并对比不同语言的性能与代码风格。
  4. 与数学问题结合

    • 可将整除判断与质因数分解、最大公约数(GCD)计算等数学问题结合,设计更复杂的应用场景。

💯小结

  • 在这里插入图片描述
    本文围绕判断整数是否能被 357 整除的问题,从问题描述出发,分析了两种代码实现方式,并提出优化方案。通过改进,我们提升了代码的效率可读性扩展性。同时,本文还探讨了该问题的潜在扩展方向,为解决更复杂的算法问题提供了参考。
    这类问题既是编程基础能力的训练,也是算法设计思维的培养。希望本文能为读者提供启发,帮助其在学习与实践中进一步提升编程能力。同时,这些方法和思路也将为更广泛的技术探索和研究提供助力。

在这里插入图片描述


在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

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

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

相关文章

【构建工具】现代开发的重要角色

你可能有所听闻构建工具&#xff0c;但是不知道是干什么的&#xff0c;或者是开发中用到了&#xff0c;大概会使用&#xff0c;但是想理解一下具体的工作原理等&#xff0c;那么我将分享一下我对其的理解。【 我将分为两篇来讲解】。 当我们谈到构建工具时&#xff0c;可以把它…

npm或yarn包配置地址源

三种方法 1.配置.npmrc 文件 在更目录新增.npmrc文件 然后写入需要访问的包的地址 2.直接yarn.lock文件里面修改地址 简单粗暴 3.yarn install 的时候添加参数 设置包的仓库地址 yarn config set registry https://registry.yarnpkg.com 安装&#xff1a;yarn install 注意…

Unity集成Wwise并进行开发

1. 背景 项目要接入WWise&#xff0c;学习一下 1.1 与Unity自带音频系统的区别 Unity有自己的原生音乐功能&#xff1a;AduioSound。但是这个功能较为简单&#xff0c;对于音效开发人员来说并不是很友好。在一些大型的游戏中&#xff0c;音效会接入Wwise这个软件。音效开发者…

【AI知识】有监督学习之回归任务(附线性回归代码及可视化)

1. 回归的基本概念 在机器学习的有监督学习中&#xff0c;回归&#xff08;Regression&#xff09;是一种常见的任务&#xff0c;它的目标是通过观察数据来建立一个模型&#xff0c;用一个或多个自变量来预测因变量的值。 回归分析通常用于&#xff1a; a.预测&#xff0c;基于…

C语言专题之宏的基本概念

合理使用宏可以使我们的代码更加简单&#xff0c;接下来小编就来讲解宏的基本概念&#xff01; 一、宏的定义 宏定义是C/C语言中一项强大而灵活的特性&#xff0c;它允许程序员使用预处理器指令来创建简化的代码表示。这种机制不仅提高了代码的可读性和可维护性&#xff0c;还…

MySQL 复合查询(重点)

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 MySQL 复合查询&#xff08;重点&#xff09; 收录于专栏[MySQL] 本专栏旨在分享学习MySQL的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; …

WPF 控件

<div id"content_views" class"htmledit_views"><p id"main-toc"><strong>目录</strong></p> WPF基础控件 按钮控件&#xff1a; Button:按钮 RepeatButton:长按按钮 RadioButton:单选按钮 数据显示控件 Te…

Docker方式安装人人影视离线完整安装包

本文软件由网友 ルリデ 推荐&#xff1b; 上周&#xff0c;人人影视创始人宣布将人人影视二十年字幕数据开源分享 目前提供了两种使用方式&#xff1a; “在线应用” &#xff1a;意味着需要有互联网才可以使用。官方提供了网站&#xff1a;https://yyets.click “离线使用” …

opencv——(图像梯度处理、图像边缘化检测、图像轮廓查找和绘制、透视变换、举例轮廓的外接边界框)

一、图像梯度处理 1 图像边缘提取 cv2.filter2D(src, ddepth, kernel[, dst[, anchor[, delta[, borderType]]]]) 功能&#xff1a;用于对图像进行卷积操作。卷积是图像处理中的一个基本操作&#xff0c;它通过一个称为卷积核&#xff08;或滤波器&#xff09;的小矩阵在图像上…

物联网安全-ARMv8-M Trustzone 实操

前言 本文针对ARMv8m架构M23/M33 MCU安全特性使用进行介绍,以nxp LPC55xx系列和STM32L5xx系列为例,为大家阐述如何使用Trustzone技术提高物联网设备安全性,适合有一定平台安全基础的物联网设备开发人员、安全方案开发人员。 背景 为了提升平台安全性,ARM推出了ARMv8m架构…

深入理解偏向锁、轻量级锁、重量级锁

一、对象结构和锁状态 synchronized关键字是java中的内置锁实现&#xff0c;内置锁实际上就是个任意对象&#xff0c;其内存结构如下图所示 其中&#xff0c;Mark Word字段在64位虚拟机下占64bit长度&#xff0c;其结构如下所示 可以看到Mark Word字段有个很重要的作用就是记录…

《拉依达的嵌入式\驱动面试宝典》—C/CPP基础篇(五)

《拉依达的嵌入式\驱动面试宝典》—C/CPP基础篇(五) 你好,我是拉依达。 感谢所有阅读关注我的同学支持,目前博客累计阅读 27w,关注1.5w人。其中博客《最全Linux驱动开发全流程详细解析(持续更新)-CSDN博客》已经是 Linux驱动 相关内容搜索的推荐首位,感谢大家支持。 《拉…

geoserver(1) 发布sql 图层 支持自定义参数

前提使用postgis 数据库支持关联 join 支持 in,not in,like,及其他sql原生函数 新增sql图层 编写自定义sql 编辑sql语句必须输出带有geom数据 正则表达式去除 设置id以及坐标参考系 预览sql图层效果 拼接sql参数 http://xxx.com/geoserver/weather/wms?SERVICEWMS&VERSI…

光谱相机

光谱相机是一种能够同时获取目标物体的空间图像信息和光谱信息的成像设备。 1、工作原理 光谱相机通过光学系统将目标物体的光聚焦到探测器上&#xff0c;在探测器前设置分光元件&#xff0c;如光栅、棱镜或滤光片等&#xff0c;将光按不同波长分解成多个光谱通道&#xff0c…

数智读书笔记系列008 智人之上:从石器时代到AI时代的信息网络简史

书名:智人之上&#xff1a;从石器时代到AI时代的信息网络简史 作者:&#xff3b;以&#xff3d;尤瓦尔赫拉利 译者:林俊宏 出版时间:2024-09-01 ISBN:9787521768527 中信出版集团制作发行 作者信息 尤瓦尔・赫拉利 1976 年出生于以色列海法&#xff0c;是牛津大学历史学…

MAC M3电脑在idea上搭建Spark环境并跑通第一个程序

我的电脑是Macbook Pro&#xff0c;最近在学习Spark&#xff0c;想要在idea里搭建Spark环境&#xff0c;为之后的Spark编程作准备。下面是在MAC版本的idea里配置Spark环境。 1. 准备工作 1.安装 JDK 确保Mac 上已经安装了 JDK 8 或更高版本。 可通过 java -version 查看是否…

WPF+MVVM案例实战与特效(三十八)- 封装一个自定义的数字滚动显示控件

文章目录 1、运行效果2、案例实现1、功能设计2、页面布局3、控件使用4、运行效果3、拓展:多数字自定义控件1、控件应用4、总结1、运行效果 在Windows Presentation Foundation (WPF)应用程序中,自定义控件允许开发者创建具有特定功能和外观的独特UI元素。本博客将介绍一个名…

Docker如何运行一个python脚本Hello World

Docker如何运行一个python脚本Hello World 1、编写Python的Hello World&#xff1a;script.py #!/usr/bin/python #_*_coding:utf-8_*_ print("Hello World") 2、Dockerfile文件 #拉取Docker环境 FROM python #设置工作目录 WORKDIR /app #将dockerfile同级文件copy到…

整数奇偶排序

整数奇偶排序 C语言代码C 代码Java代码Python代码 &#x1f490;The Begin&#x1f490;点点关注&#xff0c;收藏不迷路&#x1f490; 给定10个整数的序列&#xff0c;要求对其重新排序。排序要求: 1.奇数在前&#xff0c;偶数在后&#xff1b; 2.奇数按从大到小排序&#x…

泷羽sec学习打卡-brupsuite7搭建IP炮台

声明 学习视频来自B站UP主 泷羽sec,如涉及侵权马上删除文章 笔记的只是方便各位师傅学习知识,以下网站只涉及学习内容,其他的都 与本人无关,切莫逾越法律红线,否则后果自负 关于brupsuite的那些事儿-Brup-IP炮台搭建 搭建炮台服务端安装zmap1、更新系统和安装基础依赖&#xff…