一个整数 num 的 k 美丽值定义为 num 中符合以下条件的 子字符串 数目:
给你整数 num 和 k ,请你返回 num 的 k 美丽值。
注意: 允许有 前缀 0 。 0 不能整除任何值。 一个 子字符串 是一个字符串里的连续一段字符序列。
示例 1:
输入:num = 240, k = 2
输出:2
解释:以下是 num 里长度为 k 的子字符串:
- "240" 中的 "24" :24 能整除 240 。
- "240" 中的 "40" :40 能整除 240 。
所以,k 美丽值为 2 。
示例 2:
输入:num = 430043, k = 2
输出:2
解释:以下是 num 里长度为 k 的子字符串:
- "430043" 中的 "43" :43 能整除 430043 。
- "430043" 中的 "30" :30 不能整除 430043 。
- "430043" 中的 "00" :0 不能整除 430043 。
- "430043" 中的 "04" :4 不能整除 430043 。
- "430043" 中的 "43" :43 能整除 430043 。
所以,k 美丽值为 2 。
提示:
1 <= num <= 10^9
1 <= k <= num.length (将 num 视为字符串)
来源:力扣(LeetCode) 链接:https://leetcode.cn/problems/find-the-k-beauty-of-a-number 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
class Solution:
def divisorSubstrings(self, num: int, k: int) -> int:
strnum = str(num)
ans = 0
for i in range(len(strnum)-k+1):
if int(strnum[i:i+k]) and num % int(strnum[i:i+k]) == 0:
ans += 1
return ans
32 ms 14.9 MB Python3