优酷视频上传网站源码网站关键词查询
问题背景
一个整数 n u m num num 的 k k k 美丽值定义为 n u m num num 中符合以下条件的 子字符串 数目:
- 子字符串长度为 k k k。
- 子字符串能整除 n u m num num。
给你整数 n u m num num 和 k k k,请你返回 n u m num num 的 k k k 美丽值。
注意:
- 允许有 前缀 0 0 0。
- 0 0 0 不能整除任何值。
一个 子字符串 是一个字符串里的连续一段字符序列。
数据约束
- 1 ≤ n u m ≤ 109 1 \le num \le 109 1≤num≤109
- 1 ≤ k ≤ n u m . l e n g t h 1 \le k \le num.length 1≤k≤num.length
解题过程
按题目要求统计有多少字串能够被整除即可,需要注意一下的是完全把 n u m num num当成数字也可以做,从低位到高位用模运算和除法不断地获取当前的数字就可以了。
具体实现
class Solution {public int divisorSubstrings(int num, int k) {String str = String.valueOf(num);int res = 0;for (int i = 0; i + k <= str.length(); i++) {int cur = Integer.parseInt(str.substring(i, i + k));if (cur != 0 && num % cur == 0) {res++;}}return res;}
}