佳木斯湛栽影视文化发展公司

主頁 > 知識(shí)庫 > 利用Python來實(shí)現(xiàn)阿姆斯特朗數(shù)的檢查實(shí)例

利用Python來實(shí)現(xiàn)阿姆斯特朗數(shù)的檢查實(shí)例

熱門標(biāo)簽:語音系統(tǒng) 企業(yè)做大做強(qiáng) Win7旗艦版 百度AI接口 電話運(yùn)營中心 硅谷的囚徒呼叫中心 呼叫中心市場(chǎng)需求 客戶服務(wù)

一、什么是阿姆斯特朗數(shù)?

如果一個(gè)正整數(shù)等于其各個(gè)數(shù)字的立方和,則稱該數(shù)為阿姆斯特朗數(shù)(亦稱為自戀性數(shù))。

一個(gè)正整數(shù)稱為阿姆斯特朗階數(shù)。

例:

abcd... = an + bn + cn + dn + ...

如果是3位的阿姆斯特朗數(shù)字,則每個(gè)數(shù)字的立方和等于該數(shù)字本身。

例如:

153 = 1*1*1 + 5*5*5 + 3*3*3 // 153是一個(gè)阿姆斯特朗數(shù)。

二、案例

1. 檢查阿姆斯特朗數(shù)(3位數(shù)字)

例 :

# 檢查該數(shù)字是否為阿姆斯壯數(shù)字的Python程序

# 接受用戶的輸入
num = int(input("輸入一個(gè)數(shù)字: "))

# 初始化sum
sum = 0

# 求出每個(gè)數(shù)字的立方和
temp = num
while temp > 0:
 digit = temp % 10
 sum += digit ** 3
 temp //= 10

# 顯示結(jié)果
if num == sum:
 print(num,"是阿姆斯特朗數(shù)")
else:
 print(num,"不是阿姆斯特朗數(shù)")

輸出1

輸出2

代碼解析:

要求用戶輸入一個(gè)數(shù)字,然后檢查它是否是一個(gè)阿姆斯特朗數(shù)字,需要計(jì)算每個(gè)數(shù)字的立方和。

因此,將總和初始化為0,并使用**模運(yùn)算符(%)**獲得每個(gè)數(shù)字。將數(shù)字除以10所得的余數(shù)是該數(shù)字的最后一位。使用指數(shù)運(yùn)算符獲取多維數(shù)據(jù)集。

最后,將總和與原始數(shù)字進(jìn)行比較,得出結(jié)論,如果相等,則是阿姆斯特朗數(shù)。

2. 檢查是阿姆斯特朗的n位數(shù)字

例:

num = 1634

# 將num變量更改為string
# 并計(jì)算出長度(位數(shù))
order = len(str(num))

# 初始化 sum
sum = 0

# 求出每個(gè)數(shù)字的立方和
temp = num
while temp > 0:
 digit = temp % 10
 sum += digit ** order
 temp //= 10

# 顯示結(jié)果
if num == sum:
 print(num, "是阿姆斯特朗數(shù)")
else:
 print(num, "不是阿姆斯特朗數(shù)")

運(yùn)行結(jié)果:

注:

讀者可以更改源代碼中num的值,然后再次運(yùn)行以對(duì)其進(jìn)行測(cè)試。

3. 在整數(shù)中查找阿姆斯特朗數(shù)

例:

# Python程序在整數(shù)中查找阿姆斯特朗數(shù)

lower = 100
upper = 2000

for num in range(lower, upper + 1):

 # order 個(gè)數(shù)
 order = len(str(num))

 # 初始化 sum
 sum = 0

 temp = num
 while temp > 0:
  digit = temp % 10
  sum += digit ** order
  temp //= 10

 if num == sum:
  print(num)

運(yùn)行結(jié)果:

注:

在變量lower中設(shè)置了下限100,在變量upper中設(shè)置了上限2000。

使用了for循環(huán)來從變量lower到upper進(jìn)行迭代。在迭代中,lower的值增加1,并檢查它是否為阿姆斯特朗數(shù)。

可以更改范圍并通過更改變量lower和upper進(jìn)行測(cè)試。該變量lower應(yīng)小于upper此程序才能正常運(yùn)行。

三、總結(jié)

本文基于Python基礎(chǔ),介紹了什么是阿姆斯特朗數(shù),以及如何去判斷,檢查阿姆斯特朗數(shù),檢查是阿姆斯特朗的n位數(shù)字,在整數(shù)中查找阿姆斯特朗數(shù)。都通過案例的分析,代碼的演示,效果的展示,進(jìn)行有效的分析。

使用Python語言,能夠讓讀者更好的理解。在實(shí)際項(xiàng)目中遇到的問題,難點(diǎn),提供了有效的解決方案,供讀者參考。
代碼很簡(jiǎn)單,希望能夠幫讀者更好的學(xué)習(xí)。

到此這篇關(guān)于利用Python來實(shí)現(xiàn)阿姆斯特朗數(shù)檢查的文章就介紹到這了,更多相關(guān)Python實(shí)現(xiàn)阿姆斯特朗數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • C++和python實(shí)現(xiàn)阿姆斯特朗數(shù)字查找實(shí)例代碼

標(biāo)簽:崇左 長沙 海南 喀什 安康 濟(jì)南 山西 山西

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《利用Python來實(shí)現(xiàn)阿姆斯特朗數(shù)的檢查實(shí)例》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    湖北省| 新绛县| 乐都县| 黎城县| 景谷| 山丹县| 岑巩县| 禹城市| 临城县| 无棣县| 乌拉特前旗| 香港| 齐河县| 海淀区| 凤台县| 南江县| 双辽市| 广饶县| 黄龙县| 土默特左旗| 潢川县| 原阳县| 静海县| 盐山县| 西盟| 新晃| 江达县| 信阳市| 赤城县| 三台县| 九龙县| 桂东县| 尚义县| 云梦县| 华阴市| 宿州市| 永顺县| 浏阳市| 芦山县| 保康县| 荔浦县|