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

python 实现armstrong numbers阿姆斯壮数算法

armstrong numbers阿姆斯壮数算法介绍

阿姆斯壮数(Armstrong numbers),也称为自恋性数(Narcissistic numbers)、水仙花数(Narcissistic number,特指三位数的情形),是指一个n位数,它的每个位上的数字的n次幂之和等于它本身。例如,一个三位数abc(a、b、c分别代表百位、十位和个位),如果满足a^3 + b^3 + c^3 = abc,则它是一个三位的阿姆斯壮数。

对于更一般的情况,我们可以编写一个算法来检查任意给定的数是否为阿姆斯壮数。以下是一个Python语言的实现示例:

def is_armstrong_number(n):
    """
    检查n是否为阿姆斯壮数
    :param n: 待检查的数
    :return: 如果n是阿姆斯壮数返回True,否则返回False
    """
    # 转换为字符串方便遍历每一位
    num_str = str(n)
    # 获取位数
    order = len(num_str)
    # 初始化幂之和
    sum_of_powers = 0
    
    # 遍历每一位
    for digit in num_str:
        # 将字符转换为整数并计算其order次幂
        sum_of_powers += int(digit) ** order
    
    # 如果幂之和等于原数,则为阿姆斯壮数
    return sum_of_powers == n

# 示例
print(is_armstrong_number(153))  # True,因为 1^3 + 5^3 + 3^3 = 153
print(is_armstrong_number(123))  # False
print(is_armstrong_number(370))  # False
print(is_armstrong_number(371))  # True,因为 3^3 + 7^3 + 1^3 = 371

这个算法首先确定了一个数的位数,然后遍历每一位,将其转换为整数并计算其相应次幂的和。如果这个和等于原数,那么这个数就是一个阿姆斯壮数。

注意,这个算法的时间复杂度主要由位数决定,对于非常大的数(位数非常多),计算可能会比较慢。然而,由于阿姆斯壮数本身的定义,实际应用中很少需要处理非常大的数。

armstrong numbers阿姆斯壮数算法python实现样例

Armstrong numbers(阿姆斯壮数)是指一个 n 位数,它的每一位的 n 次幂之和等于它本身。

下面是使用 Python 实现 Armstrong numbers 的算法:

def is_armstrong_number(number):
    # 将数字转为字符串,以便遍历每一位数
    str_number = str(number)
    # 获取数字的位数
    num_digits = len(str_number)
    # 初始化阿姆斯壮数的和为0
    armstrong_sum = 0
    
    # 遍历每一位数
    for digit in str_number:
        # 将字符串类型的数字转为整数类型
        digit = int(digit)
        # 计算每一位数的 n 次幂,并加到阿姆斯壮数的和中
        armstrong_sum += digit ** num_digits
    
    # 判断阿姆斯壮数的和是否等于原始数字
    if armstrong_sum == number:
        return True
    else:
        return False


# 测试阿姆斯壮数算法
for i in range(1, 1001):
    if is_armstrong_number(i):
        print(i)

在上面的代码中,is_armstrong_number 函数用于判断给定的数字是否为阿姆斯壮数。我们遍历数字的每一位数,将每一位数的 n 次幂加到阿姆斯壮数的和中,最后判断阿姆斯壮数的和是否等于原始数字。如果相等,则说明该数字是阿姆斯壮数。

在测试部分,我们遍历从 1 到 1000 的所有数字,并调用 is_armstrong_number 函数来判断是否是阿姆斯壮数,如果是,则打印该数字。

运行以上代码,会输出以下结果:

1
2
3
4
5
6
7
8
9
153
370
371
407

http://www.kler.cn/news/311693.html

相关文章:

  • 利用pandas为海量数据添加UUID并实现精准筛选
  • 开放标准如何破解企业数字化与可持续发展的困境:The Open Group引领生态系统架构创新
  • 新电脑工作流搭建记录-前端篇
  • 《ElementUI/Plus 基础知识》el-table + sortablejs 实现 row 拖动改变顺序(Vue2/3适用)
  • C++对C的扩充
  • 二百六十六、Hive——Hive的DWD层数据清洗、清洗记录、数据修复、数据补全
  • ros跨平台订阅和发布消息(ip如何设置)
  • Springboot的三层架构
  • ⭐ Unity + OpenCV 实现实时图像识别与叠加效果
  • HTML基础和常用标签
  • 【C++笔记】八、结构体 [ 3 ]
  • 如何着手创建企业数据目录?(一)数据目录的设定
  • python 实现area under curve曲线下面积算法
  • libserailport交叉编译适配说明
  • 胤娲科技:解锁AI奥秘——产品经理的智能进化之旅
  • 【每天学点AI】一个例子带你了解Python装饰器到底在干嘛!
  • C语言中的一些小知识(二)
  • Android 恢复挑战和解决方案:如何从 Android 设备恢复删除的文件
  • 算法题总结(三)——滑动窗口
  • MySql的基础讲解
  • Fisco Bcos 2.11.0配置console控制台2.10.0及部署调用智能合约
  • SpringAI-基于java大模型的胡言乱语
  • 正则表达式获取某些字段
  • docker快速搭建kafka
  • 【C++ Primer Plus习题】16.9
  • ATGM331C-5T杭州中科微BDS/GNSS全星座定位授时模块应用领域
  • 数据结构---二叉树例题讲解
  • 基于深度学习的手势识别算法(论文复现)
  • Vue使用组件需要加前缀而React使用组件库的区别
  • 单片机毕业设计基于单片机寻迹巡线避障智能小车系统设计