C++中计算范围内仅包含非零数字且数字和为N且能被M整除的数字个数


我们提供了两个数字START和END来定义一个数字范围。目标是在范围[START,END]中找到所有没有数字0且数字和等于给定数字N的数字。此外,这些数字可以被M整除。

我们将通过遍历从START到END的数字来实现这一点,并对每个数字,我们将使用while循环计算其数字的和(仅当所有数字都不为零时)。如果此和等于N并且数字可以被M整除,则增加计数。

让我们通过示例来理解。

输入 

START=1 END=100 N=9 M=6

输出 

Numbers with digit sum N and divisible by M: 4

解释 

Numbers 18, 36, 54, 72 have digit sum=9 and divisible by 6. None has 0 as a digit.

输入 

START=100 END=200 N=10 M=2

输出 

Numbers with digit sum N and divisible by M: 4

解释 

Numbers 118, 136, 154, 172 have digit sum=10 and divisible by 2. None has 0 as a digit.

下面程序中使用的算法如下

  • 我们获取整数START、END、N和M。

  • 函数digitSum(int start, int end, int n, int m)返回数字和=n且能被m整除且所有数字都不为零的数字的个数。

  • 将初始变量count设置为0,表示此类数字的个数。

  • 将变量digsum设置为0。

  • 将变量flag设置为0。

  • 使用for循环遍历数字范围。i=start到i=end

  • 现在对于每个数字num=i,如果num%m==0(能被m整除),则继续执行。

  • 使用while循环检查数字是否>0。并找到数字。

  • digit=num%10。如果digit不为零,则计算digsum+=digit。将num=num/10减少以添加下一个数字。如果任何数字为0,则将flag=0并中断while循环。

  • 在while循环结束时,检查是否( digsum == n and flag==1 )。如果是,则增加count。

  • 现在将i增加m(以m的倍数增加)。

  • 在所有循环结束时,count将包含满足条件的数字总数。

  • 返回count作为结果。

示例

 实时演示

#include <bits/stdc++.h>
using namespace std;
int digitSum(int start, int end, int n, int m){
   int count = 0;
   int digsum = 0;
   int flag=0;
   for (int i = start; i <= end; i++){
      int num=i;
      digsum=0;
      flag=0;
      if(num%m==0){
         while(num>0){
            int digit=num%10;
            if(digit==0){
               flag=0;
               break;
            }
            digsum+=num%10; //sum of digits
            num=num/10;
            flag=1;
         }
         if(digsum==n && flag==1) //original number is i {
            count++;
            cout<<i<<" ";
         }
         i+=m; //now increment in multiples of m
         i--; // for loop has i++
      }
   }
   return count;
}
int main(){
   int START = 1;
   int END = 100;
   int N = 9;
   int M = 6;
   cout <<"Numbers with digit sum N and divisible by M: "<<digitSum(START,END,N, M);
   return 0;
}

Explore our latest online courses and learn new skills at your own pace. Enroll and become a certified expert to boost your career.

输出

如果我们运行以上代码,它将生成以下输出:

Numbers with digit sum N and divisible by M: 4

更新时间: 2020年10月31日

326 次浏览

开启您的职业生涯

通过完成课程获得认证

立即开始
广告