Моя квадратная корневая программа по какой-то причине получает ответ, который немного отличается от того, что он должен получить для большинства входных данных. Я не знаю, почему это так. Только определенные входы неверны. Я также получаю ошибку сегментации на том самом конце после ответа, и я не уверен, почему это так.C++ Квадратный корень с рекурсией
#include<iostream>
#include<cmath>
#include<cfloat>
#include<string>
#include <cstdlib>
using namespace std;
//declare sqroot function calls recursive function newton
double sqroot1(double num);
double newton(double num, double guess);
int main(int argc, char **argv)
{
for(int i = 0 ; i < argc ; i++)
{
cout<<"sqroot("<<argv[i+1]<<") is "<< sqroot1(atoi(argv[i+1])) <<endl;
}
}
double newton(double num, double a)
{
if ((abs(a*a - num) <= FLT_EPSILON))
{
return a;
}
else
{
newton(num, (a+num/a)/2);
}
}
double sqroot1(double num)
{
double sqrt = newton(num,num/2);
return sqrt;
}
Включите все предупреждения и посмотрите, что говорит вам компилятор. И см. [Почему «использование пространства имен std» считается плохой практикой?] (Http://stackoverflow.com/q/1452721/995714) –
Каковы некоторые значения, которые дают плохие квадратные корни и какие значения вы получаете за них? – 1201ProgramAlarm