Leetcode LCP 06. 拿硬币

Leetcode LCP 06. 拿硬币

题目描述

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

欢迎大家关注我的个人公众号,同样的也是和该博客账号一样,专注分享技术问题,我们一起学习进步
Leetcode LCP 06. 拿硬币_第1张图片

你可能感兴趣的:(leetcode刷题,c++,算法,leetcode,拿硬币,数据结构)