2
Contributors
7
Replies
8
Views
5 Years
Discussion Span
Last Post by thines01
0

This is the code I have written so far. Right now the code only gets the polynomial, later it will create the derivative. The error is not in the code itself. It runs until all the coefficients are input and then I get the bad access thing.

#include <iostream>
#include <cmath>

using namespace std;

double poly(double[], int);
double drv(double[], int, double);

int main ()
{
	int n;
	cout << "Enter the degrees of the polynomial: ";
	cin >> n;
	
	double c[n];
	
	for (int i=n; i>=0; i--) 
	{
		cout << "Enter the coefficient for the variable of degree " << i << ": ";
		cin >> c[i];
	}
    
	cout << "The polynomial entered is: " << poly(c,n) << endl; //I think this is where it's messing up
	
	return 0;
}

double poly(double c[], int n)
{
	double sum=0.0;
	double x;
	
	for (int i=0; i<=n; i--) 
	{
		sum+=c[i]*pow(x, i);
	}
	
	return sum;
}
0

Does your compiler compile this?
You are allocating an array with a non-constant (line 15)

Also x is never initialized and is used on line 35.

0

What does this mean?

You are allocating an array with a non-constant (line 15)

The compiler compiles it until it reaches the point where it's supposed to pick up from the function, so something is wrong with the function. The x is because I want it to say that it's the coefficient (c) times x^i, because later on in the program I need it to take the derivative.

0

If your intention is to use the pow() function, both parameters need to have actual values.
...meaning: The variable x needs a value before you use it.

Edited by thines01: n/a

This topic has been dead for over six months. Start a new discussion instead.
Have something to contribute to this discussion? Please be thoughtful, detailed and courteous, and be sure to adhere to our posting rules.