Saturday, 18 November 2017

C++ Program to Implement Fermat Primality Test


Code:

#include   cstring
#include   iostream
#include   cstdlib
#define ll long long
using namespace std;
/* 
 * modular exponentiation
 */
ll modulo(ll base, ll exponent, ll mod)
{
    ll x = 1;
    ll y = base;
    while (exponent > 0)
    {
        if (exponent % 2 == 1)
            x = (x * y) % mod;
        y = (y * y) % mod;
        exponent = exponent / 2;
    }
    return x % mod;
}

/* 
 * Fermat's test for checking primality 
 */
bool Fermat(ll p, int iterations)
{
    if (p == 1)
    {
        return false;
    }
    for (int i = 0; i < iterations; i++)
    {
        ll a = rand() % (p - 1) + 1; 
        if (modulo(a, p - 1, p) != 1)
        { 
            return false;
        }
    }
    return true;
}
/* 
 * Main
 */
int main()
{
    int iteration = 50;
    ll num;
    cout<<"Enter integer to test primality: ";
    cin>>num;
    if (Fermat(num, iteration))
        cout<
    else
        cout<
    return 0;
}


Output:

Enter integer to test primality: 479001599
479001599 is prime

------------------
(program exited with code: 1)
Press return to continue



More C++ Programs:













100+ Best Home Decoration Ideas For Christmas Day 2019 To Make Home Beautiful

Best gifts for Christmas Day | Greeting cards for Christmas Day | Gift your children a new gift on Christmas day This Christmas d...