【算法训练】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;
}

浙公网安备 33010602011771号