好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > python 算法題——快樂數的多種解法

python 算法題——快樂數的多種解法

熱門標簽:電銷機器人的風險 開封語音外呼系統代理商 應電話機器人打電話違法嗎 手機網頁嵌入地圖標注位置 河北防封卡電銷卡 開封自動外呼系統怎么收費 地圖標注線上如何操作 天津電話機器人公司 400電話辦理哪種

題目描述:

編寫一個算法來確定一個數字是否“快樂”。 快樂的數字按照如下方式確定:從一個正整數開始,用其每位數的平方之和取代該數,并重復這個過程,直到最后數字要么收斂等于1且一直等于1,要么將無休止地循環下去且最終不會收斂等于1。能夠最終收斂等于1的數就是快樂的數字。

例如:19是一個快樂數字,計算過程如下:

1^2+9^2=82
8^2+2^2=68
6^2+8^2=100
1^2+0^2+0^2=1
要求:當輸入快樂的數字時,輸出True,否則輸出False。

思路:

1. 當輸入的不是快樂數字時,會陷入一個無限循環,因此增加一個計數器 count 用來統計計算次數。設定當 count 達到2000次時,認為該數字不是快樂數字,跳出循環結束計算。
2. 因為不確定輸入的數字會是幾位數,因此不采用除法和取模的方法來獲得數字的每一位數,而是利用 for 循環獲取字符串類型數字的每一位來計算平方和。

代碼:

#快樂的數字
def getSumofSquares(num):
    numStr=str(num) #將待計算的數字轉換成字符串類型
    sum=0
    digitls=[int(x) for x in numStr] #從字符串中提取出每一位數字存入一個列表
    #注:該步略顯多余,因為python中字符串可以和列表一樣切片取值或循環,見下方更新部分
    #print(digitls)
    for i in digitls:
        sum += i**2
    return sum

def main():
    n = input() #輸入一個正整數
    sumofSqrs = eval(n)
    count = 0
    while sumofSqrs != 1:
        sumofSqrs = getSumofSquares(sumofSqrs)
        count += 1
        if count > 2000: #當計算次數超過2000次時,跳出循環結束計算
            print("False")
            break
    else:
        print("True")

main()

改良版

根據網友在評論區提出的不快樂的數字最終會在 [4,16,37,58,89,145,42,20] 這些數字中無限循環,因此可以加入判斷,當數字變為這些數字里的任意一個(比如4)時就結束循環,輸出False,從而避免無限循環的產生。

修改后的代碼:

#(新)快樂的數字
def getSumofSquares(num):
    numStr=str(num)
    sum=0
    for i in numStr:
        sum += int(i)**2
    return sum

def main():
    n = input() #n為一個正整數
    sumofSqrs = eval(n)
    while sumofSqrs != 1 and sumofSqrs != 4: #或 while sumofSqrs not in [1,4,16,37,58,89,145,42,20]
        sumofSqrs = getSumofSquares(sumofSqrs)
    else:
        if sumofSqrs == 1:
            print("True")
        else:
            print("False")

main()

采用遞歸

def happy(n):
        try:
                if n==1:
                        print('True')
                else:
                        new = str(n)
                        sum = 0
                        for c in new:
                                sum += int(c)**2
                        return happy(sum)
        except Exception as e:
                print('False')
                # print(e)

n = eval(input())
happy(n)

數學方法

        d = {}
        while True:
            m = 0
            while n > 0:
                m += (n%10)**2
                n //= 10 
            if m in d:
                return False
            if m == 1:
                return True
            d[m] = m
            n = m

優化過的

class Solution(object):
    def isHappy(self, n):
        """
        :type n: int
        :rtype: bool
        """
        record = []
        sq_sum = 0
        se_n = n

        while se_n != 1:
            sq_sum = 0
            while se_n > 0:
                sq_sum += (se_n % 10) * (se_n % 10)
                se_n = se_n / 10
            if sq_sum in record:
                return False
            record.append(sq_sum)
            se_n = sq_sum

        return True

以上就是python 算法題——快樂數的多種解法的詳細內容,更多關于python 算法題快樂數的資料請關注腳本之家其它相關文章!

您可能感興趣的文章:
  • python使用ProjectQ生成量子算法指令集
  • Python機器學習算法之決策樹算法的實現與優缺點
  • Python集成學習之Blending算法詳解
  • python3實現Dijkstra算法最短路徑的實現
  • Python實現K-means聚類算法并可視化生成動圖步驟詳解
  • Python自然語言處理之切分算法詳解
  • python入門之算法學習
  • Python實現機器學習算法的分類

標簽:駐馬店 蘭州 山東 江蘇 六盤水 常州 宿遷 成都

巨人網絡通訊聲明:本文標題《python 算法題——快樂數的多種解法》,本文關鍵詞  python,算法,題,快樂,數,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python 算法題——快樂數的多種解法》相關的同類信息!
  • 本頁收集關于python 算法題——快樂數的多種解法的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 色欧美成人精品a∨在线观看| 好大好爽好猛我要喷水了视频| 嗯啊啊嗯边打电话边做| 8x8Ⅹ8X成人免费视频A片| 中文字幕一区二区二区| 911国产自产精品a| 天天干天天操天天爽| 亚洲国产片A片无限看A片| 欧美日韩精品一区二区无码视频| 再深点灬好舒服灬太大了添gif| 人妻 丝袜美腿 中文字幕 | 啊宝贝嗯太深了哦h| 一夜未拔h| 热辣文| 泰国人妖胸随便摸视频| 男主酒后出轨h| 欧美成人511性影院视频社区| 精品国产999| 成人免费网站在线观看| 欧美黄色大片在线观看| 50岁老女人毛片一级亚洲| 久久这里只是精品免费视频| 在线视频免费国产成人| 打屁股3可扒内裤版的游戏| 国产成人秘?在线观看免费网站| 青柠影视在线播放观看高清免费| 1024视频污下载| 好紧好湿太硬了我太爽了小说| 国语对白刺激真实精品| 日韩免费观看的一级毛片| 日韩精品三级| 国产对白粗大硬爽视频| 美女黄色网站| 久久精品全国免费观看国产| 热血综艺片剧 国产伦子系列午睡沙发| 看男科一般要花多少钱| XXXXX做受大片视频麻豆0| 金莎朗19禁电影在线观看| 国产毛片自拍| 噜噜噜狠狠夜夜躁精品| 日本熟人妻人伦A片悠田优|