目录
目录
题目
给你一个整数 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
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/subtract-the-product-and-sum-of-digits-of-an-integer
思路:
题目较为简单,画图解析过程省略
1.边界处理
if(n<1||n>100000){
return 0;
}
2.定义两个变量一个存积(muti)一个存和(sum)
int muti=1;
int sum=0;
3.遍历通过取余得到末位,除法去掉末位位数
while (n!=0){
//n与10取余得到末位
muti*=n%10;//累成
sum+=n%10;//累加
//每次除以10,去掉一个地位,int 类型正好是整数
n/=10;
}
4.返回结果
//积-和
return muti-sum;
完整代码
public int productSubtractSum(int n){
//1.边界处理
if(n<1||n>100000){
return 0;
}
//2.定义两个变量一个存积(muti)一个存和(sum)
int muti=1;
int sum=0;
//3.遍历通过取余得到末位,除法去掉末位位数
while (n!=0){
//n与10取余得到末位
muti*=n%10;//累成
sum+=n%10;//累加
//每次除以10,去掉一个地位,int 类型正好是整数
n/=10;
}
//积-和
return muti-sum;
}