LeetCode 整数的各位积和之差

2021-01-31  本文已影响0人  吴敬悦

给你一个整数 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

提示:

我的算法实现为:

class Solution {
    public int subtractProductAndSum(int n) {
        int sum1 = 1;
        int sum2 = 0;
        int i = Math.abs(n);
        while (i != 0) {
            sum1 *= i%10;
            sum2 += i%10;
            i /= 10;
        }
        return sum1 - sum2;
    }
}

不知道为啥使用 java 实现都是 0ms 。思路很简答,就是将每一数同时乘和加,然后相减。这个很简单,官方的解法也是跟我一样实现的。


来源:力扣(LeetCode)

上一篇下一篇

猜你喜欢

热点阅读