📌  相关文章
📜  找出除 X^X 的最小数

📅  最后修改于: 2021-10-25 06:21:11             🧑  作者: Mango

给定一个数X ,找出除X X 的大于 1 的最小数。在给定的问题中,始终假定 X 大于 1。
例子:

方法:
这个问题的主要观察是,如果一个数P除以X ,那么它也除以X X ,所以我们不需要计算X X的值。我们需要做的是找到能整除 X 的最小数,它永远是素数。
下面是上述方法的实现:

C++
// C++ implementation of above approach
#include 
using namespace std;
 
// Function to find the required smallest number
int SmallestDiv(int n)
{
  
    for (int i = 2; i * i <= n; i++) {
        // Finding smallest number that divides n
        if (n % i == 0) {
 
            // i divides n and return this
            // value immediately
            return i;
        }
    }
  
    // If n is a prime number then answer should be n,
    // As we can't take 1 as our answer.
    return n;
}
  
// Driver Code
int main()
{
  
    int X = 385;
  
    int ans = SmallestDiv(X);
    cout << ans << "\n";
  
    return 0;
}


Java
// Java implementation of above approach
class GFG{
 
// Function to find the
// required smallest number
static int SmallestDiv(int n)
{
    for(int i = 2; i * i <= n; i++)
    {
         
       // Finding smallest number
       // that divides n
       if (n % i == 0)
       {
 
           // i divides n and return this
           // value immediately
           return i;
       }
    }
 
    // If n is a prime number then
    // answer should be n, as we
    // can't take 1 as our answer.
    return n;
}
 
// Driver Code
public static void main(String[] args)
{
    int X = 385;
    int ans = SmallestDiv(X);
     
    System.out.print(ans + "\n");
}
}
 
// This code is contributed by gauravrajput1


Python3
# Python3 implementation of above approach
 
# Function to find the required smallest number
def SmallestDiv(n):
   
    i = 2
    while i * i <= n:
 
        # Finding smallest number that divides n
        if (n % i == 0):
  
            # i divides n and return this
            # value immediately
            return i
        i += 1
     
    # If n is a prime number then answer should be n,
    # As we can't take 1 as our answer.
    return n
   
# Driver Code
if __name__=="__main__":
 
    X = 385
    ans = SmallestDiv(X)
 
    print(ans)
 
# This code is contributed by Yash_R


C#
// C# implementation of above approach
using System;
 
class GFG {
     
// Function to find the
// required smallest number
static int SmallestDiv(int n)
{
    for(int i = 2; i * i <= n; i++)
    {
         
       // Finding smallest number
       // that divides n
       if (n % i == 0)
       {
            
           // i divides n and return this
           // value immediately
           return i;
       }
    }
 
    // If n is a prime number then
    // answer should be n, as we
    // can't take 1 as our answer.
    return n;
}
 
// Driver code
public static void Main(String[] args)
{
    int X = 385;
    int ans = SmallestDiv(X);
     
    Console.Write(ans + "\n");
}
}
 
// This code is contributed by shivanisinghss2110


Javascript


Output: 5

时间复杂度: O(sqrt(X))

如果您希望与专家一起参加现场课程,请参阅DSA 现场工作专业课程学生竞争性编程现场课程