91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

劍指offer:整數中1出現的次數

發布時間:2020-07-15 12:20:52 來源:網絡 閱讀:221 作者:Jayce_SYSU 欄目:編程語言

題目描述
求出1~13的整數中1出現的次數,并算出100~1300的整數中1出現的次數?為此他特別數了一下1~13中包含1的數字有1、10、11、12、13因此共出現6次,但是對于后面問題他就沒轍了。ACMer希望你們幫幫他,并把問題更加普遍化,可以很快的求出任意非負整數區間中1出現的次數(從1 到 n 中1出現的次數)。

# -*- coding: utf-8 -*-
# @Time         : 2019-07-09 16:50
# @Author       : Jayce Wong
# @ProjectName  : job
# @FileName     : numberOf1Between1AndN.py
# @Blog         : https://blog.51cto.com/jayce1111
# @Github       : https://github.com/SysuJayce

class Solution:
    """
    要計算從1到n的數字中“1”出現的個數,暴力解題的時間復雜度很高,因此需要先觀察規律進行歸納總結。

    對于個位數: 0-9有1個,以10為間隔,即10-19有1個,20-29有1個。
    對于十位數:10-19有10個,以100為間隔,即110-119有10個
    對于百位數:100-199有100個,以1000為間隔,即1100-1199有100個
    ……
    因此觀察寫出通項公式:
                (n // (i * 10)) * i + min(max(n % (i * 10) - i + 1, 0), i)
    """
    def NumberOf1Between1AndN_Solution(self, n):
        if n < 1:
            return 0

        count = 0
        i = 1

        while i <= n:
            count += n // (i * 10) * i + min(max(n % (i * 10) - i + 1, 0), i)
            i *= 10

        return count
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

门头沟区| 普宁市| 宜君县| 陇川县| 凭祥市| 沙坪坝区| 城步| 清水县| 团风县| 枣强县| 台中市| 秭归县| 铁岭县| 泌阳县| 乌兰浩特市| 六安市| 茂名市| 江油市| 加查县| 马公市| 义乌市| 峨眉山市| 西贡区| 瑞昌市| 桃江县| 密云县| 高尔夫| 江西省| 铜鼓县| 红桥区| 和硕县| 山丹县| 阳江市| 依安县| 普兰店市| 富宁县| 长泰县| 晋城| 祥云县| 高碑店市| 芦山县|