#include <stdio.h>
#include <math.h>
int get_polynomial_degree( int polynomial_degree) ;
void get_polynomial_coefficients( int polynomial_degree, double polynomial_coefficients[ ] ) ;
int get_possible_roots_size( int polynomial_degree, double polynomial_coefficients[ ] ) ;
void get_possible_roots( int polynomial_degree, double polynomial_coefficients[ ] , double possible_roots[ ] , int a0_over_an_size) ;
int get_number_of_factors_a0( double polynomial_coefficients[ ] ) ;
int get_number_of_factors_an( int polynomial_degree, double polynomial_coefficients[ ] ) ;
void get_factors_a0( double polynomial_coefficients[ ] , int factors_a0[ ] ) ;
void get_factors_an( int polynomial_degree, double polynomial_coefficients[ ] , int factors_an[ ] ) ;
int get_a0_over_an_size( int num_factors_a0, int num_factors_an, int factors_a0[ ] , int factors_an[ ] ) ;
void get_a0_over_an( int p_numerator[ ] , int p_denominator[ ] , int factors_a0[ ] , int factors_an[ ] , int num_factors_a0, int num_factors_an) ;
int get_gcd( int num1, int num2) ;
int get_rational_roots_size( int polynomial_degree, double polynomial_coefficients[ ] , double possible_roots[ ] , int num_possible_roots) ;
void get_rational_roots( int polynomial_degree, double polynomial_coefficients[ ] , double possible_roots[ ] , int num_possible_roots, double rational_roots[ ] ) ;
int main( )
{
int i;
int polynomial_degree = get_polynomial_degree( polynomial_degree) ;
double polynomial_coefficients[ polynomial_degree] ;
get_polynomial_coefficients( polynomial_degree, polynomial_coefficients) ;
int num_possible_roots = 2 * get_possible_roots_size( polynomial_degree, polynomial_coefficients) ;
double possible_roots[ num_possible_roots] ;
get_possible_roots( polynomial_degree, polynomial_coefficients, possible_roots, num_possible_roots) ;
printf ( "The input degree is: %d\n " , polynomial_degree
) ; printf ( "The input coefficients are: " ) ; for ( i = 0 ; i < polynomial_degree+ 1 ; i++ )
{
printf ( "%0.4lf " , polynomial_coefficients
[ i
] ) ; }
printf ( "There are %d possible_roots." , num_possible_roots
) ; printf ( "The possible roots are: \n " ) ; for ( i = 0 ; i < num_possible_roots; i++ )
{
printf ( "%0.4lf \n " , possible_roots
[ i
] ) ; }
int num_rational_roots = get_rational_roots_size( polynomial_degree, polynomial_coefficients, possible_roots, num_possible_roots) ;
double rational_roots[ num_rational_roots] ;
get_rational_roots( polynomial_degree, polynomial_coefficients, possible_roots, num_possible_roots, rational_roots) ;
if ( num_rational_roots >= 1 )
{
printf ( "The number of rational roots is: %d\n " , num_rational_roots
) ; for ( i = 0 ; i < num_rational_roots; i++ )
{
printf ( "%0.4lf " , rational_roots
[ i
] ) ; }
}
else if ( num_rational_roots == 0 )
{
printf ( "There are no rational roots for this input.\n " ) ; }
return 0 ;
}
int get_polynomial_degree( int polynomial_degree)
{
printf ( "Enter the highest degree of the input polynomial: \n " ) ; scanf ( "%d" , & polynomial_degree
) ;
return polynomial_degree;
}
void get_polynomial_coefficients( int polynomial_degree, double polynomial_coefficients[ ] )
{
int i;
printf ( "Enter %d integer coefficients starting from 0th degree.\n " , polynomial_degree
+ 1 ) ; printf ( "Separate each input by a comma: \n " ) ; for ( i = 0 ; i <= polynomial_degree; i++ )
{
scanf ( "%lf, " , & polynomial_coefficients
[ i
] ) ; }
}
int get_possible_roots_size( int polynomial_degree, double polynomial_coefficients[ ] )
{
int num_factors_a0, num_factors_an;
num_factors_a0 = get_number_of_factors_a0( polynomial_coefficients) ;
num_factors_an = get_number_of_factors_an( polynomial_degree, polynomial_coefficients) ;
int factors_a0[ num_factors_a0] , factors_an[ num_factors_an] ;
get_factors_a0( polynomial_coefficients, factors_a0) ;
get_factors_an( polynomial_degree, polynomial_coefficients, factors_an) ;
int i, j, gcd, size = num_factors_a0 * num_factors_an;
for ( i = 0 ; i < num_factors_a0; i++ )
{
for ( j = 0 ; j < num_factors_an; j++ )
{
gcd = get_gcd( factors_a0[ i] , factors_an[ j] ) ;
if ( gcd != 1 )
{
size--;
}
}
}
return size;
}
void get_possible_roots( int polynomial_degree, double polynomial_coefficients[ ] , double possible_roots[ ] , int a0_over_an_size)
{
int num_factors_a0, num_factors_an;
num_factors_a0 = get_number_of_factors_a0( polynomial_coefficients) ;
num_factors_an = get_number_of_factors_an( polynomial_degree, polynomial_coefficients) ;
int factors_a0[ num_factors_a0] , factors_an[ num_factors_an] ;
get_factors_a0( polynomial_coefficients, factors_a0) ;
get_factors_an( polynomial_degree, polynomial_coefficients, factors_an) ;
a0_over_an_size = get_a0_over_an_size( num_factors_a0, num_factors_an, factors_a0, factors_an) ;
int p_numerator[ a0_over_an_size] , p_denominator[ a0_over_an_size] ;
get_a0_over_an( p_numerator, p_denominator, factors_a0, factors_an, num_factors_a0, num_factors_an) ;
int i;
for ( i = 0 ; i < a0_over_an_size; i++ )
{
possible_roots[ i * 2 ] = ( double ) p_numerator[ i] / ( double ) p_denominator[ i] ;
possible_roots[ i * 2 + 1 ] = - ( double ) p_numerator[ i] / ( double ) p_denominator[ i] ;
}
}
int get_number_of_factors_a0( double polynomial_coefficients[ ] )
{
int divisorCount = 1 , i;
int abs_polynomial_coefficients_0 = polynomial_coefficients[ 0 ] ;
abs_polynomial_coefficients_0
= fabs ( abs_polynomial_coefficients_0
) ;
if ( abs_polynomial_coefficients_0 == 0 || abs_polynomial_coefficients_0 == 1 )
{
return divisorCount;
}
else
{
for ( i = 2 ; i * i < ( int ) abs_polynomial_coefficients_0; ++ i)
{
if ( ( int ) abs_polynomial_coefficients_0 % i == 0 )
{
++ divisorCount;
}
}
divisorCount *= 2 ;
if ( i * i == ( int ) abs_polynomial_coefficients_0)
{
++ divisorCount;
}
return divisorCount;
}
}
int get_number_of_factors_an( int polynomial_degree, double polynomial_coefficients[ ] )
{
int divisorCount = 1 , i;
int abs_polynomial_coefficients_n = polynomial_coefficients[ polynomial_degree] ;
abs_polynomial_coefficients_n
= fabs ( abs_polynomial_coefficients_n
) ;
if ( abs_polynomial_coefficients_n == 0 || abs_polynomial_coefficients_n == 1 )
{
return divisorCount;
}
else
{
for ( i = 2 ; i * i < ( int ) abs_polynomial_coefficients_n; ++ i)
{
if ( ( int ) abs_polynomial_coefficients_n % i == 0 )
{
++ divisorCount;
}
}
divisorCount *= 2 ;
if ( i * i == ( int ) abs_polynomial_coefficients_n)
{
++ divisorCount;
}
return divisorCount;
}
}
void get_factors_a0( double polynomial_coefficients[ ] , int factors_a0[ ] )
{
int i, element = 0 ;
int abs_polynomial_coefficients_0 = polynomial_coefficients[ 0 ] ;
abs_polynomial_coefficients_0
= fabs ( abs_polynomial_coefficients_0
) ;
if ( abs_polynomial_coefficients_0 == 0 )
{
factors_a0[ 0 ] = 0 ;
}
else
{
for ( i= 1 ; i<= ( int ) abs_polynomial_coefficients_0; ++ i)
{
if ( ( int ) abs_polynomial_coefficients_0% i== 0 )
{
factors_a0[ element] = i;
element++;
}
}
}
}
void get_factors_an( int polynomial_degree, double polynomial_coefficients[ ] , int factors_an[ ] )
{
int i, element = 0 ;
int abs_polynomial_coefficients_n = polynomial_coefficients[ polynomial_degree] ;
abs_polynomial_coefficients_n
= fabs ( abs_polynomial_coefficients_n
) ; if ( abs_polynomial_coefficients_n == 0 )
{
factors_an[ 0 ] = 0 ;
}
else
{
for ( i= 1 ; i<= ( int ) abs_polynomial_coefficients_n;++ i)
{
if ( ( int ) abs_polynomial_coefficients_n% i== 0 )
{
factors_an[ element] = i;
element++;
}
}
}
}
int get_a0_over_an_size( int num_factors_a0, int num_factors_an, int factors_a0[ ] , int factors_an[ ] )
{
int i, j, gcd, size = num_factors_a0 * num_factors_an;
for ( i = 0 ; i < num_factors_a0; i++ )
{
for ( j = 0 ; j < num_factors_an; j++ )
{
gcd = get_gcd( factors_a0[ i] , factors_an[ j] ) ;
if ( gcd != 1 )
{
size--;
}
}
}
return size;
}
void get_a0_over_an( int p_numerator[ ] , int p_denominator[ ] , int factors_a0[ ] , int factors_an[ ] , int num_factors_a0, int num_factors_an)
{
int i, j, gcd, element = 0 ;
for ( i = 0 ; i < num_factors_a0; i++ )
{
for ( j = 0 ; j < num_factors_an; j++ )
{
gcd = get_gcd( factors_a0[ i] , factors_an[ j] ) ;
if ( gcd == 1 )
{
p_numerator[ element] = factors_a0[ i] ;
p_denominator[ element] = factors_an[ j] ;
element++;
}
}
}
}
int get_gcd( int num1, int num2)
{
while ( num1!= num2)
{
if ( num1> num2)
num1-= num2;
else
num2-= num1;
}
return num1;
}
int get_rational_roots_size( int polynomial_degree, double polynomial_coefficients[ ] , double possible_roots[ ] , int num_possible_roots)
{
int i, j, num_rational_roots = 0 ;
double quotient_coefficients[ polynomial_degree] ;
quotient_coefficients[ 0 ] = polynomial_coefficients[ polynomial_degree] ;
for ( i = 0 ; i < num_possible_roots; i++ )
{
for ( j= 1 ; j<= polynomial_degree; j++ )
{
quotient_coefficients[ j] = ( quotient_coefficients[ j- 1 ] * possible_roots[ i] ) + polynomial_coefficients[ polynomial_degree- j] ;
if ( quotient_coefficients[ 2 ] == 0 && j == 2 )
{
num_rational_roots++;
}
}
}
return num_rational_roots;
}
void get_rational_roots( int polynomial_degree, double polynomial_coefficients[ ] , double possible_roots[ ] , int num_possible_roots, double rational_roots[ ] )
{
int i, j, element = 0 ;
double quotient_coefficients[ polynomial_degree] ;
quotient_coefficients[ 0 ] = polynomial_coefficients[ polynomial_degree] ;
for ( i = 0 ; i < num_possible_roots; i++ )
{
for ( j= 1 ; j<= polynomial_degree; j++ )
{
quotient_coefficients[ j] = ( quotient_coefficients[ j- 1 ] * possible_roots[ i] ) + polynomial_coefficients[ polynomial_degree- j] ;
printf ( "Result %d = %lf\t " , j
, quotient_coefficients
[ j
] ) ; if ( quotient_coefficients[ 2 ] == + 0 || quotient_coefficients[ 2 ] == - 0 )
{
rational_roots[ element] = possible_roots[ i] ;
printf ( "\n Root %lf at i = %d, j = %d\n " , rational_roots
[ element
] , i
, j
) ; element++;
}
}
}
}
#include <stdio.h>
#include <math.h>
int	 get_polynomial_degree(int polynomial_degree);
void	 get_polynomial_coefficients(int polynomial_degree, double polynomial_coefficients[]);

int  get_possible_roots_size(int polynomial_degree, double polynomial_coefficients[]);
void get_possible_roots(int polynomial_degree, double polynomial_coefficients[], double possible_roots[], int a0_over_an_size);
int 		get_number_of_factors_a0(double polynomial_coefficients[]);
int 		get_number_of_factors_an(int polynomial_degree, double polynomial_coefficients[]);
void		get_factors_a0(double polynomial_coefficients[], int factors_a0[]);
void 		get_factors_an(int polynomial_degree, double polynomial_coefficients[], int factors_an[]);
int 		get_a0_over_an_size(int num_factors_a0, int num_factors_an, int factors_a0[], int factors_an[]);
void 		get_a0_over_an(int p_numerator[], int p_denominator[], int factors_a0[], int factors_an[], int num_factors_a0, int num_factors_an);
int 		get_gcd(int num1, int num2);

int  get_rational_roots_size(int polynomial_degree, double polynomial_coefficients[], double possible_roots[], int num_possible_roots);
void get_rational_roots(int polynomial_degree, double polynomial_coefficients[], double possible_roots[], int num_possible_roots, double rational_roots[]);



int main()
{
	int i;
	
	int polynomial_degree = get_polynomial_degree(polynomial_degree);
	double polynomial_coefficients[polynomial_degree];
	get_polynomial_coefficients(polynomial_degree, polynomial_coefficients);
	
	int num_possible_roots = 2 * get_possible_roots_size(polynomial_degree, polynomial_coefficients);
	double possible_roots[num_possible_roots];
	get_possible_roots(polynomial_degree, polynomial_coefficients, possible_roots, num_possible_roots);
	
	
	printf("The input degree is: %d\n", polynomial_degree);
	printf("The input coefficients are: ");
	for(i = 0; i < polynomial_degree+1; i++)
	{
		printf("%0.4lf ", polynomial_coefficients[i]);
	}
	printf("\n");

	
	printf("There are %d possible_roots.", num_possible_roots);
	printf("The possible roots are: \n");
	for(i = 0; i < num_possible_roots; i++)
	{
		printf("%0.4lf \n", possible_roots[i]);
	}
	printf("\n"); 	
	
	int num_rational_roots = get_rational_roots_size(polynomial_degree, polynomial_coefficients, possible_roots, num_possible_roots);
	double rational_roots[num_rational_roots];
	get_rational_roots(polynomial_degree, polynomial_coefficients, possible_roots, num_possible_roots, rational_roots);
	
	if(num_rational_roots >= 1)
	{
		printf("The number of rational roots is: %d\n", num_rational_roots);
		printf("Root/s are: ");
		for(i = 0; i < num_rational_roots; i++)
		{
			printf("%0.4lf ", rational_roots[i]);
		}
	}
	else if(num_rational_roots == 0)
	{
		printf("There are no rational roots for this input.\n");
	}
	
	
	return 0;
}

int get_polynomial_degree(int polynomial_degree)
{
	printf("Enter the highest degree of the input polynomial: \n");
	scanf("%d", &polynomial_degree);
	
	return polynomial_degree;
}

void get_polynomial_coefficients(int polynomial_degree, double polynomial_coefficients[])
{
	int i;
	
	printf("Enter %d integer coefficients starting from 0th degree.\n", polynomial_degree+1);
	printf("Separate each input by a comma: \n");
	for(i = 0;i <= polynomial_degree; i++)
	{
		scanf("%lf, ", &polynomial_coefficients[i]);
	}
}

int get_possible_roots_size(int polynomial_degree, double polynomial_coefficients[])
{
	int num_factors_a0, num_factors_an;
	num_factors_a0 = get_number_of_factors_a0(polynomial_coefficients);
	num_factors_an = get_number_of_factors_an(polynomial_degree, polynomial_coefficients);
	
	int factors_a0[num_factors_a0], factors_an[num_factors_an];
	get_factors_a0(polynomial_coefficients, factors_a0);
	get_factors_an(polynomial_degree, polynomial_coefficients, factors_an);

	int i, j, gcd, size = num_factors_a0 * num_factors_an;
	for(i = 0; i < num_factors_a0;i++)
	{
		for(j = 0; j < num_factors_an;j++)
		{
			gcd = get_gcd(factors_a0[i], factors_an[j]);
			if(gcd != 1)
			{
				size--;
			}
		}
	}
	return size;
}

void get_possible_roots(int polynomial_degree, double polynomial_coefficients[], double possible_roots[], int a0_over_an_size)
{
	int num_factors_a0, num_factors_an;
	num_factors_a0 = get_number_of_factors_a0(polynomial_coefficients);
	num_factors_an = get_number_of_factors_an(polynomial_degree, polynomial_coefficients);
	
	int factors_a0[num_factors_a0], factors_an[num_factors_an];
	get_factors_a0(polynomial_coefficients, factors_a0);
	get_factors_an(polynomial_degree, polynomial_coefficients, factors_an);
	
	a0_over_an_size = get_a0_over_an_size(num_factors_a0, num_factors_an, factors_a0, factors_an);
	int p_numerator[a0_over_an_size], p_denominator[a0_over_an_size];
	get_a0_over_an(p_numerator, p_denominator, factors_a0, factors_an, num_factors_a0, num_factors_an);	


    int i;
    for (i = 0; i < a0_over_an_size; i++)
    {
        possible_roots[i * 2] = (double)p_numerator[i]/(double)p_denominator[i];
        possible_roots[i * 2 + 1] = -(double)p_numerator[i]/(double)p_denominator[i];
    }
}

int get_number_of_factors_a0(double polynomial_coefficients[])
{
	int divisorCount = 1, i;
	int abs_polynomial_coefficients_0 = polynomial_coefficients[0];
	abs_polynomial_coefficients_0 = fabs(abs_polynomial_coefficients_0);
	
	if(abs_polynomial_coefficients_0 == 0 || abs_polynomial_coefficients_0 == 1)
	{
		return divisorCount;
	}
	else
	{
		for(i = 2; i * i < (int)abs_polynomial_coefficients_0; ++i)
		{
			if((int)abs_polynomial_coefficients_0 % i == 0)
			{
				++divisorCount;
			}
		}
		divisorCount *= 2;
		if(i * i == (int)abs_polynomial_coefficients_0)
		{
			++divisorCount;
		}
		return divisorCount;
	}
}

int get_number_of_factors_an(int polynomial_degree, double polynomial_coefficients[])
{
	int divisorCount = 1, i;
	int abs_polynomial_coefficients_n = polynomial_coefficients[polynomial_degree];
	abs_polynomial_coefficients_n = fabs(abs_polynomial_coefficients_n);
	
	if(abs_polynomial_coefficients_n == 0 || abs_polynomial_coefficients_n == 1)
	{
		return divisorCount;
	}
	else
	{
		for(i = 2; i * i < (int)abs_polynomial_coefficients_n; ++i)
		{
			if((int)abs_polynomial_coefficients_n % i == 0)
			{
				++divisorCount;
			}
		}
		divisorCount *= 2;
		if(i * i == (int)abs_polynomial_coefficients_n)
		{
			++divisorCount;
		}
		return divisorCount;
	}
}

void get_factors_a0(double polynomial_coefficients[], int factors_a0[])
{
	int i, element = 0;
	int abs_polynomial_coefficients_0 = polynomial_coefficients[0];
	abs_polynomial_coefficients_0 = fabs(abs_polynomial_coefficients_0);
	
	if(abs_polynomial_coefficients_0 == 0)
	{
		factors_a0[0] = 0;
	}
	else
	{
		for(i=1; i<= (int)abs_polynomial_coefficients_0; ++i)
		{
			if((int)abs_polynomial_coefficients_0%i==0)
			{
				
				factors_a0[element] = i;
				element++;
			}
		}
	}
}

void get_factors_an(int polynomial_degree, double polynomial_coefficients[], int factors_an[])
{
	int i, element = 0;
	int abs_polynomial_coefficients_n = polynomial_coefficients[polynomial_degree];
	abs_polynomial_coefficients_n = fabs(abs_polynomial_coefficients_n);
	if(abs_polynomial_coefficients_n == 0)
	{
		factors_an[0] = 0;
	}
	else
	{
		for(i=1;i<=(int)abs_polynomial_coefficients_n;++i)
	  {
		  if((int)abs_polynomial_coefficients_n%i==0)
		  {
				
				factors_an[element] = i;
				element++;
		  }
	  }
	}
}

int get_a0_over_an_size(int num_factors_a0, int num_factors_an, int factors_a0[], int factors_an[])
{
	int i, j, gcd, size = num_factors_a0 * num_factors_an;
	for(i = 0; i < num_factors_a0;i++)
	{
		for(j = 0; j < num_factors_an;j++)
		{
			gcd = get_gcd(factors_a0[i], factors_an[j]);
			if(gcd != 1)
			{
				size--;
			}
		}
	}
	return size;
}

void get_a0_over_an(int p_numerator[], int p_denominator[], int factors_a0[], int factors_an[], int num_factors_a0, int num_factors_an)
{
	int i, j, gcd, element = 0;
	
	for(i = 0; i < num_factors_a0;i++)
	{
		for(j = 0; j < num_factors_an;j++)
		{
			gcd = get_gcd(factors_a0[i], factors_an[j]);
			if(gcd == 1)
			{
				p_numerator[element] = factors_a0[i];
				p_denominator[element] = factors_an[j];
				element++;
			}
		}
	}
}

int get_gcd(int num1, int num2)
{
	while(num1!=num2)
	{
		if(num1>num2)
			num1-=num2;
		else
			num2-=num1;
	}
	return num1;
}

int  get_rational_roots_size(int polynomial_degree, double polynomial_coefficients[], double possible_roots[], int num_possible_roots)
{
	int i, j, num_rational_roots = 0;
	double quotient_coefficients[polynomial_degree];
	
	quotient_coefficients[0] = polynomial_coefficients[polynomial_degree];
	for(i = 0; i < num_possible_roots; i++)
	{
		for(j=1;j<=polynomial_degree;j++)
		{
			quotient_coefficients[j] = (quotient_coefficients[j-1]*possible_roots[i])+polynomial_coefficients[polynomial_degree-j];
			if(quotient_coefficients[2] == 0 && j == 2)
			{
				num_rational_roots++;
			}
		}
	}
	return num_rational_roots;
}

void get_rational_roots(int polynomial_degree, double polynomial_coefficients[], double possible_roots[], int num_possible_roots, double rational_roots[])
{
	int i, j, element = 0;
	double quotient_coefficients[polynomial_degree];
	
	quotient_coefficients[0] = polynomial_coefficients[polynomial_degree];
	for(i = 0; i < num_possible_roots; i++)
	{
		for(j=1;j<=polynomial_degree;j++)
		{
			quotient_coefficients[j] = (quotient_coefficients[j-1]*possible_roots[i])+polynomial_coefficients[polynomial_degree-j];
			printf("Result %d = %lf\t", j, quotient_coefficients[j]);
			if(quotient_coefficients[2] == +0 || quotient_coefficients[2] == -0)
			{
				rational_roots[element] = possible_roots[i];
				printf("\nRoot %lf at i = %d, j = %d\n", rational_roots[element], i, j);
				element++;
			}
		}
		printf("\n");
	}
}