标签:1出现的次数 时间 复杂 and pre min job 间隔 time
题目描述# -*- 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
标签:1出现的次数 时间 复杂 and pre min job 间隔 time
原文地址:https://blog.51cto.com/jayce1111/2418688