Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> C++

หาจำนวน X ที่น้อยที่สุดเพื่อให้ X! มีอย่างน้อย Y ศูนย์ต่อท้ายใน C++


เราต้องใช้ตัวเลข Y เราจะหาจำนวน X ที่น้อยที่สุด เช่น X! มีจำนวนศูนย์การฝึกอย่างน้อย Y ตัวอย่างเช่น ถ้า Y =2 ค่าของ X =10 เป็น X! =3228800 มีจำนวนศูนย์ Y

เราสามารถแก้ไขได้โดยใช้การค้นหาแบบไบนารี จำนวนศูนย์ต่อท้ายใน N! ถูกกำหนดโดยการนับปัจจัย 5 ใน N! X สามารถพบได้โดยใช้การค้นหาแบบไบนารีในช่วง [0, 5*Y]

ตัวอย่าง

#include<iostream>
using namespace std;
int factorCount(int n, int X) {
   if (X < n)
      return 0;
   return (X / n + factorCount(n, X / n));
}
int findX(int Y) {
   int left = 0, right = 5 * Y;
   int N = 0;
   while (left <= right) {
      int mid = (right + left) / 2;
   if (factorCount(5, mid) < Y) {
      left = mid + 1;
   }else {
      N = mid;
      right = mid - 1;
      }
   }
   return N;
}
int main() {
   int Y = 4;
   cout << "Smallest value of X: " << findX(Y);
}

ผลลัพธ์

Smallest value of X: 20