如果一个整数能够被其各个数位上的数字之和整除,则称之为 哈沙德数(Harshad number)。给你一个整数 x
。如果 x
是 哈沙德数 ,则返回 x
各个数位上的数字之和,否则,返回 -1
。
示例 1:
输入: x = 18
输出: 9
解释:
x
各个数位上的数字之和为 9
。18
能被 9
整除。因此 18
是哈沙德数,答案是 9
。
示例 2:
输入: x = 23
输出: -1
解释:
x
各个数位上的数字之和为 5
。23
不能被 5
整除。因此 23
不是哈沙德数,答案是 -1
。
class Solution:
def sumOfTheDigitsOfHarshadNumber(self, x: int) -> int:
# 计算 x 的各个数位上的数字之和
digit_sum = sum(int(digit) for digit in str(x))
# 判断 x 是否能被 digit_sum 整除
if x % digit_sum == 0:
return digit_sum
else:
return -1