在C++中查找一个数x,使得x与其各位数字之和等于给定的n


这里我们将看到一个问题,我们取一个数字n,必须找到另一个值,比如x,使得x加上x的各位数字之和等于给定的数字n。假设n的值是21。该程序将返回数字x = 15,因为15 + 15的各位数字之和,即15 + 1 + 5 = 21 = n。

为了解决这个问题,我们必须遵循简单的方法。我们将从1迭代到n,在每次迭代中,我们将查看数字及其各位数字之和是否与该数字相同,如果是,则停止,否则继续。

示例

 在线演示

#include<iostream>
using namespace std;
int getDigitSum(int n) {
   int sum = 0;
   while (n) {
      sum += n % 10;
      n /= 10;
   }
   return sum;
}
int getNumber(int n) {
   for (int i = 0; i <= n; i++)
      if (i + getDigitSum(i) == n)
         return i;
         return -1;
}
int main() {
   int n = 21;
   cout << "The value of x is: " << getNumber(n);
}

输出

The value of x is: 15

更新于:2019年10月24日

288 次浏览

开启你的职业生涯

完成课程获得认证

开始学习
广告