当前位置: 首页 > news >正文

python经典百题之水仙花数

题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数

本身。例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。

方法一:暴力穷举法

思路:先从100开始,依次枚举每个三位数,然后求该数的各位数字的立方和,判断该数是否等于这个立方和。

优点:思路简单,易于理解和实现。

缺点:时间复杂度较高,需要枚举所有的三位数,因此效率较低。

代码实现如下:

for num in range(100, 1000):temp = numsum = 0while temp:digit = temp % 10sum += digit ** 3temp //= 10if sum == num:print(num)

方法二:优化穷举法

思路:可以在穷举的过程中加入一些剪枝操作,例如可以只对各位数字和为指定值的数进行计算,这样可以减少不必要的计算。

优点:在一定程度上提高了效率。

缺点:仍然需要枚举所有的三位数。

代码实现如下:

for i in range(1, 10):for j in range(0, 10):for k in range(0, 10):num = i * 100 + j * 10 + kif num == i ** 3 + j ** 3 + k ** 3:print(num)

方法三:数学公式法

思路:根据水仙花数的定义,可以得到一个三位数的各位数字立方和的公式,即 num = i3 + j3 + k**3。根据这个公式,可以迅速判断一个数是否是水仙花数。

优点:不需要枚举所有的三位数,直接根据公式进行判断,效率较高。

缺点:思维难度较大,难以想到该公式。

代码实现如下:

for num in range(100, 1000):i = num // 100j = num // 10 % 10k = num % 10if num == i**3 + j**3 + k**3:print(num)

综上所述,数学公式法是最优解,但需要对数学公式有一定的理解和掌握。暴力穷举法虽然简单易懂,但效率较低,优化穷举法则在一定程度上提高了效率,但仍需要枚举所有的三位数。

http://www.lryc.cn/news/167012.html

相关文章:

  • jvm的调优工具
  • C语言--字符串旋转笔试题
  • IntelliJ IDEA使用_常规设置
  • ResponseBodyAdvice 获取参数
  • 人力资源服务升级正当时,法大大助力佩信集团加速数字化
  • UG\NX二次开发 二维向量相加
  • RabbitMQ深入 —— 持久化和发布确认
  • 人脸识别三部曲
  • 【Linux网络编程】Socket-TCP实例
  • <OpenCV> 边缘填充
  • 【视觉SLAM入门】7.3.后端优化 基于KF/EKF和基于BA图优化的后端,推导及举例分析
  • Docker概念通讲
  • PHP请求API接口案例采集电商平台数据获取淘宝/天猫优惠券查询示例
  • 计算机网络:三次握手与四次挥手
  • Visual Studio 调试上传文件时自动停止运行的解决方法
  • 使用scp命令失败出错
  • kafka增加磁盘或者分区,topic重分区
  • SpringMVC系列(五)之JSR303和拦截器
  • LCP 01.猜数字
  • 智能小车开发
  • RDMA性能测试工具集preftest_README
  • 墨天轮专访星环科技刘熙:“向量热”背后的冷思考,Hippo如何打造“先发”优势?
  • 逆向-beginners之非递归
  • Spring for Apache Kafka概述和简单入门
  • 基于SSM+Vue的医院医患管理系统
  • 再次理解Android账号管理体系
  • 如何在Blender中压缩/减小GLTF模型的大小
  • IntelliJ IDEA使用_Plugin插件推荐
  • Ajax fetch navigator.sendBeacon 三个的区别
  • map-reduce执行过程