【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

提示:

  • 1 <= n <= 10^5

解答

源代码

class Solution {
    public int subtractProductAndSum(int n) {
        int product = 1, sum = 0;
        int temp = n % 10;

        while (n != 0) {
            product *= temp;
            sum += temp;
            n = n / 10;
            temp = n % 10;
        }

        return product - sum;
    }
}

总结

每次计算出当前位的数字,然后进行计算,注意乘积的初始值为1,和的初始值0。

你可能感兴趣的:(LeetCode,leetcode,算法,java)