在C ++中检查15是否可除以大数

在这里,我们将看到如何检查一个数字是否可以被15整除。在这种情况下,这个数字非常大。因此,我们将数字作为字符串。

要检查一个数字是否可以被15整除,如果该数字可以被5整除,又可以被3整除,那么要检查被5整除,我们必须看到最后一个数字是0或5。要被3整除,我们将看到数字总和是否可以被3整除。

示例

#include <bits/stdc++.h>
using namespace std;
bool isDiv15(string num){
   int n = num.length();
   if(num[n - 1] != '5' && num[n - 1] != '0')
      return false;
      long sum = accumulate(begin(num), end(num), 0) - '0' * n;
   if(sum % 3 == 0)
      return true;
      return false;
}
int main() {
   string num = "154484585745184258458158245285260";
   if(isDiv15(num)){
      cout << "Divisible";
   } else {
      cout << "Not Divisible";
   }
}

输出结果

Divisible