Leetcode 1281. 整数的各位积和之差
题目描述
给你一个整数 n
,请你帮忙计算并返回该整数「各位数字之积」与「各位数字之和」的差。
示例1:
输入:n = 234
输出:15
解释:
各位数之积 = 2 * 3 * 4 = 24
各位数之和 = 2 + 3 + 4 = 9
结果 = 24 - 9 = 15
示例2:
输入:n = 4421
输出:21
解释:
各位数之积 = 4 * 4 * 2 * 1 = 32
各位数之和 = 4 + 4 + 2 + 1 = 11
结果 = 32 - 11 = 21
解题思路
根据题目描述,求出整数n的各个数字,然后计算它们的积和差;对于一个整数n,我们从低位开始计算,对整数n进行取余操作,然后对整数n再进行取整操作,就可以得到它的个位;然后再重复这个操作,就可以得到新的整数n的各位数。
代码如下:
class Solution {
public:
int subtractProductAndSum(int n) {
int res = 0;
int product = 1;
int sum = 0;
while(n > 0){
product *= n%10;
sum += n%10;
n /= 10;
}
res = product - sum;
return res;
}
};
欢迎大家关注我的个人公众号,同样的也是和该博客账号一样,专注分享技术问题,我们一起学习进步