【算法训练】LeetCode#1486 数组异或操作

一、描述

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

二、思路

按位运算的考察

三、解题

Java

public class LeetCode1281 {
    public int subtractProductAndSum(int n) {
        int h = 0;
        int j = 1;
        while (n > 0){
            h += n%10;
            j *= n%10;
            n /= 10;
        }
        return j-h;
    }
}

C++

int subtractProductAndSum(int n) {

    int h = 0;
    int j = 1;

    while (n > 0){
        h += n%10;
        j *= n%10;
        n /= 10;
    }

    return j - h;
}
posted @ 2023-07-02 17:30  小拳头呀  阅读(7)  评论(0)    收藏  举报