2269.找到一个数字的K美丽值
https://leetcode.cn/problems/find-the-k-beauty-of-a-number/
一个整数 num 的 k 美丽值定义为 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^91 <= k <= num.length(将num视为字符串)
python
class Solution:
def divisorSubstrings(self, num: int, k: int) -> int:
s = str(num)
n = len(s)
if k > n: # 如果k大于num的位数,则直接返回0
return 0
cnt = 0
for i in range(n - k + 1): # 确保考虑到所有长度为k的子串
sub_num = int(s[i:i+k])
if sub_num != 0 and num % sub_num == 0: # 检查是否为有效除数
cnt += 1
return cnt