ในที่นี้เราจะมาดูวิธีการตรวจสอบตัวเลขที่หารด้วย 2, 3 และ 5 ว่าลงตัวหรือไม่ ในกรณีนี้จำนวนเป็นจำนวนที่มาก ดังนั้นเราจึงใส่ตัวเลขเป็นสตริง
ตัวเลขจะหารด้วย 2, 3 และ 5 ลงตัวถ้าตัวเลขนั้นหารด้วย LCM ที่ 2,3 และ 5 ลงตัว ดังนั้น LCM ของ 2, 3, 5 จึงเป็น 30 เราต้องเช็คว่าจำนวนนั้นหารด้วย 30 ลงตัวหรือไม่ ตัวเลขหารด้วย 30 ลงตัวเมื่อหารด้วย 10 ลงตัว (หลักสุดท้ายคือ 0) และหารด้วย 3 ลงตัว (ผลรวมของตัวเลขทั้งหมดหารด้วย 3)
ตัวอย่าง
#include <bits/stdc++.h>
using namespace std;
bool isDiv30(string num){
int n = num.length();
if(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 = "353730746028908374890";
if(isDiv30(num)){
cout << "Divisible";
} else {
cout << "Not Divisible";
}
} ผลลัพธ์
Divisible