• 每日一程-16.python-巴比伦平方根算法


    Author: Notus(hehe_xiao@qq.com)
    Create: 2019-02-23
    Update: 2019-02-23

    巴比伦平方根算法

    环境

    Python version: 3.7.1

    代码如下(a.py)

    '''
    	巴比伦平方根算法实现。
    	@Author: Notus(hehe_xiao@qq.com)
    	@Create: 2019-02-23
    	@Update: 2019-02-23
    	@Version: 0.1
    	
    	算法步骤:
    	1. 猜测数字的平方根。
    	2. 用猜测的数字除原数。
    	3. 计算步骤2的商与猜测数的平均值
    	4. 将第3步的平均值再作猜测(当成新猜测值,继续猜测)
    	5. 如果新的猜测值与旧的猜测值不同(即上一猜测值,用他们的差值是否大于公差来判断);否则停止
    '''
    
    import math
    
    num_str = input("输入需要计算平方根的整数:")
    while not num_str.isdigit():
    	num_str = input("非法输入!
    请重新输入一个整数:")
    number_int = int(num_str)
    
    guess_str = input("输入猜测值:")
    while not guess_str.isdigit():
    	guess_str = input("非法输入!
    请重新输入一个猜测数(浮点数):")
    guess_float = float(guess_str)
    original_float = guess_float
    
    tolerance_float = float(input("请输入一个公差(浮点数):"))
    
    previous_guess = 0
    count_int = 0
    while math.fabs(previous_guess - guess_float) > tolerance_float:
    	previous_guess = guess_float
    	quotient = number_int / guess_float 
    	guess_float = (quotient + guess_float) / 2
    	count_int += 1
    
    print("{0} 的平方根为: {1}".format(number_int, guess_float))
    print("公差为 {}".format(tolerance_float))
    print("共猜测了 {} 次".format(count_int))
    print("原猜测为 {}".format(original_float))
    

    运行结果

    C:UsersNotusDesktop>python a.py
    输入需要计算平方根的整数:2
    输入猜测值:1
    请输入一个公差(浮点数):0.000000000000001
    2 的平方根为: 1.414213562373095
    公差为 1e-15
    共猜测了 6 次
    原猜测为 1.0
    
  • 相关阅读:
    ANDROID BINDER机制浅析
    ANDROID权限机制
    运算符
    Give root password for maintenance
    安装python工具
    gitlab
    jumpserver
    python环境安装
    inode
    升级openssh漏洞
  • 原文地址:https://www.cnblogs.com/leo1875/p/10424541.html
Copyright © 2020-2023  润新知