用python二分法求平方根,这个程序为什么错了?要求:编写程序,输入一个在[0,1]范围内的小数x,用二分法求x的平方根.我写的程序是这样的:def main():x=input('x')n=0if x=0:guess=0.5if abs(x-guess**2)=0.0000001

来源:学生作业帮助网 编辑:作业帮 时间:2024/11/08 20:33:00

用python二分法求平方根,这个程序为什么错了?要求:编写程序,输入一个在[0,1]范围内的小数x,用二分法求x的平方根.我写的程序是这样的:def main():x=input('x')n=0if x=0:guess=0.5if abs(x-guess**2)=0.0000001
用python二分法求平方根,这个程序为什么错了?
要求:编写程序,输入一个在[0,1]范围内的小数x,用二分法求x的平方根.
我写的程序是这样的:
def main():
x=input('x')
n=0
if x=0:
guess=0.5
if abs(x-guess**2)=0.0000001:
guess=(guess+0)/2
else:
guess=(guess+1)/2
return guess
else:
print 'x在0到1之间'
main()
我自己跑了几遍这个程序发现结果经常是0.75,明显不正确,但是又不知道这个程序什么地方出错了?请帮我看一下

用python二分法求平方根,这个程序为什么错了?要求:编写程序,输入一个在[0,1]范围内的小数x,用二分法求x的平方根.我写的程序是这样的:def main():x=input('x')n=0if x=0:guess=0.5if abs(x-guess**2)=0.0000001
首先二分法肯定需要一个“不断”二分的过程,你的代码里面连一个循环都没有,肯定是不对的吧?
其次按照你的代码的思路,如果当前估算值guess的平法比x大,那就往0那边靠,否则就往1那边靠,这个好像也不对吧?
二分法的实现方法应该是,在区间[left,right]里面找x的开方,令估算值为guess等于区间的中点,如果guess比实际的大,那就把区间缩小一半,令到右端点移动到中点,如果guess比实际的小,也是将区间缩小一半,但是是令左端点移动到中点.这样每次缩小一半的区间,直到区间的长度非常非常小,那就认为区间的两个端点是相等的了,这个时候就得到了答案.
import math

def main():
\x09x = input('x=')
\x09n = 0
\x09if x <= 1 and x >= 0:
\x09\x09left = 0.
\x09\x09right = 1.
\x09\x09while right - left >= 0.0000001:
\x09\x09\x09guess = (left + right) / 2.
\x09\x09\x09if guess ** 2 - x >= 0.0000001:
\x09\x09\x09\x09right = guess
\x09\x09\x09else:
\x09\x09\x09\x09left = guess
\x09\x09#return guess
\x09\x09print 'sqrt(x) is', left
\x09else:
\x09\x09print 'x should be in [0,1]'

if __name__ == '__main__':
\x09main()
 我按照你的思路又写了另外一种方法:
def second():
\x09x = input('x=')
\x09n = 0
\x09if x <= 1 and x >= 0:
\x09\x09movelen = (1 + 0) / 4.
\x09\x09guess = (1 + 0) / 2.
\x09\x09while abs(guess ** 2 - x) >= 0.0000001:
\x09\x09\x09if (guess ** 2 - x) >= 0.0000001:
\x09\x09\x09\x09guess = guess - movelen
\x09\x09\x09else:
\x09\x09\x09\x09guess = guess + movelen
\x09\x09\x09movelen = movelen / 2.
\x09\x09print 'sqrt(x) is', guess
\x09else:
\x09\x09print 'x should be in [0,1]'

用python二分法求平方根,这个程序为什么错了?要求:编写程序,输入一个在[0,1]范围内的小数x,用二分法求x的平方根.我写的程序是这样的:def main():x=input('x')n=0if x=0:guess=0.5if abs(x-guess**2)=0.0000001 用二分法求近视值的程序 求用MATLAB编制方程求根的二分法和Newton法的 Matlab 程序!求用MATLAB编制方程求根的二分法和Newton法的 Matlab 程序.利用所编制的程序,的最小正根,要求精度 .其中二分法的有根区间取为 【4.0,4.6】, 用二分法求 二分法求方程的实根用二分法求方程x*x-6x-1=0在X=2附近的一个实根,要使迭代精度为1e-8这个程序对吗?#include#includevoid main(){ float x1,x2,xk,fx1,fx2,fxk;cin>>x1>>x2;do{fx1=x1*x1-6*x1-1;fx2=x2*x2-6*x2-1;if(fx1*fx2>0) C语言用二分法求解的具体程序C语言二分法求方程实根,f(x)=x^6+5x^5+3x^4+x^3-7x^2+7x-20=0,根的区间是[-2,5]步长为h=0.2,误差不大于0.000001 给出具体的程序, 二分法 算法写出用 二分法 求 根号5 用C语言编写程序 :输入一个在[0,1]范围内的小数,用二分法求√x的值. 写出用二分法求方程X²-3=0(X>0)的近似解的程序 编写程序,用二分法求一元二次方程4x2+3x-6=0在(-10,10)区间的根. C语言:用二分法求方程的根,求具体可用程序;用二分法求下面方程在(-10,10)之间的一个根.2x3 - 4x2 + 3x - 6 = 0输入:一个小于1的非负实数e,它的值表示所能允许的误差输出:一个实数,其值为求 这个程序是用二分法求方程X的4次方-3x+1在区间0.3到0.4的根,要求误差不超过0.2×10的负2次方越快越好呀! matlab中利用二分法编程求方程x^3-3*x^2-x+3=0在[0,3]内的根程序已有,但第四行中f =@(x)x^3-3*x^2-x+3的 “@(x)”作用是什么?我在书上都没有见过这个符号,但不用这个符号的话程序是错误的,到底为 用python算完全数之和的方法?这是我们的作业:编写程序,编写一个程序求 2~20000 内的所有完全数之和.(一个数的所有因子之和为其本身的数称为完全数 http://baike.baidu.com/view/19074.htm?fr=aladdin#5_ 已知函数f(x)=x^5-5x+6,用二分法求这个函数的一个零点时,可将初始区间取为多少? 写出用二分法求方程在[1,2]内的一个近似解(精确度为0.1)的一个算法,并用循环语句描述这个算法. C语言求平方根的程序 用python做一个判断多个数字是否为偶数或奇数的程序用python做一个判断4个数字是否为偶数或奇数的程序,并且在最后说出1.奇数的数目比偶数多 2.偶数比奇数多 3.奇数和偶数一样多