您的位置:首页 > 其它

二分法实现开方

2017-11-27 15:11 218 查看
#include<iostream>
using namespace std;

double sqrt(double n){
double a=0,b=n;
double c=(a+b)/2;
while ((c*c)!=n) {
if (c*c>n) {
b=c;
c=(a+b)/2;//左移
}
else
{
a=c;
c=(a+b)/2;//右移
}
}
return c;

}

int main(){
int n;
while (scanf("%d",&n)!=EOF) {
cout<<sqrt(n)<<endl;
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: