剑指offer之031-整数中1出现的次数(从1到n整数中1出现的次数)

题目描述

求出1~1300的整数中1出现的次数?为此他特别数了一下1~13中包含1的数字有1、10、11、12、13因此共出现6次,但是对于后面问题他就没辙了。ACMer希望你们帮帮他,并把问题更加普遍化,可以很快的求出任意非负整数区间中1出现的次数(从1 到 n 中1出现的次数)。

思路

以百位为例:

  • 百位数为0,情况由更高位决定,10022,百位数字出现1的情况:100-199,1100-1199,2100-2199,…9100-9199,共100*10=1000种。即高位(10) * 位置(100)
  • 百位数为1,情况由更高位和百位决定,10122,百位数字出现1的情况为:100-199, 1100-1199, 2100-2199,…9100-9199,10100-10122,共1000+23种。即高位(10) * 位置(100) + 低位(23)
  • 百位数大于1,10222,百位数出现1的情况为: 100-199, 1100-1199, …9100-9199, 10100-10199 共1100种。即(高位(10)+1) * 位置(100)

最终统计所有位置可能的1的情况。时间复杂度O(logn)

def NumberOf1Between1AndN_Solution(n):
    # write code here
    res = 0
    i = 1  # 个位开始
    while n // i != 0:
        high = n//(i*10) # 高位数
        current = (n//i) % 10  # 第i位数
        low = n - (n//i) * i  # 低位数
        if current == 0:
            res += high * i
        elif current == 1:
            res += high * i + low + 1
        else:
            res += (high+1) * i
        i *= 10
    return res

print(NumberOf1Between1AndN_Solution(20))

关于明柳梦少

坚守自己的原则,不随波逐流。

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注