ถ้าเรามีจำนวนเต็ม A และ B สองจำนวน และ B>=A เราต้องคำนวณหลักสุดท้ายของ B! / เอ! เมื่อค่าของ A =2 และ B =4 ผลลัพธ์จะเป็น 2, 2! =2 และ 4! =24 ดังนั้น 24/2 =12 หลักสุดท้ายคือ 2
อย่างที่เราทราบดีว่าตัวเลขสุดท้ายของแฟคทอเรียลจะอยู่ในชุด {0, 1, 2, 4, 6} จากนั้นทำตามขั้นตอนเหล่านี้เพื่อแก้ปัญหา -
- เราจะพบความแตกต่างระหว่าง A และ B
- ถ้าต่าง>=5 คำตอบคือ 0
- มิฉะนั้น ให้ทำซ้ำจาก (A + 1) ถึง B จากนั้นคูณและเก็บไว้
- หลักสุดท้ายของการคูณจะเป็นคำตอบ
ตัวอย่าง
#include<iostream> using namespace std; int findLastDigit(long long int A, long long int B) { int x = 1; if (A == B) return 1; else if ((B - A) >= 5) return 0; else { for (long long int i = A + 1; i <= B; i++) x = (x * (i % 10)) % 10; return x % 10; } } int main() { cout << "Last digit is: " << findLastDigit(2, 4); }
ผลลัพธ์
Last digit is: 2