C++ pow()
Data-scaling algorithm and the curve-plotting routine
#include <iostream> #include <cmath> using namespace std; int main()//from w ww . j a va2 s . c o m { const int MAXPOINTS = 100; int i, npts, nval[MAXPOINTS]; double x, fval, ymin, ymax, width, sval[MAXPOINTS]; char label[] = " y axis"; char axis[] = "+---------------------------------------------------->"; char line[] = "| "; ymax = 1.0e-5; ymin = 1.0e5; width = 53; i = 1; for (x = -5.0; x <= 5.0; x += 0.5) { sval[i] = pow(x,3.0); if (sval[i] > ymax) ymax = sval[i]; if (sval[i] < ymin) ymin = sval[i]; i++; if (i >= MAXPOINTS) break; // don't exceed the maximum points } npts = i - 1; for (i=1; i <= npts; i++) { fval = (sval[i] - ymin)/(ymax - ymin) * (width - 1) + 1; nval[i] = fval + 0.5; // convert to an integer value } // Produce the plot cout << "Minimum y value: " << ymin << endl; cout << "Maximum y value: " << ymax << endl; cout << label << endl; cout << axis << endl; for (i = 1; i <= npts; i++) { line[(nval[i] + 2)] = '*'; // set character to an asterisk cout << line << endl; // output the line line[(nval[i] + 2)] = ' '; // reset character to a blank } return 0; }