leetcode-1281. 整数的各位积和之差

目录

目录

题目

思路:

完整代码

力扣风采



题目

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

提示:

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;
    }

力扣风采

leetcode-1281. 整数的各位积和之差_第1张图片

你可能感兴趣的:(数据结构和算法,leetcode,算法)