求正整数N的平方根

double SqrtN(unsigned int n)
{

         double low=0;
         double high=n;

           if (n<=4)
              {
                     low=n/2;
              }
         else
            {
                   high=n/2;
            }


         double sqrtValue=n/2;
 

         while((sqrtValue*sqrtValue>n?sqrtValue*sqrtValue-n:n-sqrtValue*sqrtValue)>1e-8)
         { 
                  sqrtValue=(low+high)/2;
                  if (sqrtValue*sqrtValue>n)
                          {
                                   high=sqrtValue;
                          } 
                  else
                          {
                                   low=sqrtValue;
                          }
  
          }


         return sqrtValue;
}

### 回答1: 下面是 Python 代码,用于计算正整数的正平方根: ``` import math def sqrt(n): return math.sqrt(n) if n >= 0 else None print(sqrt(16)) # 4.0 print(sqrt(-16)) # None ``` 这段代码使用了 Python 内置的 `math` 库,调用了它的 `sqrt` 函数来计算正整数的正平方根。此代码还检查了输入是否为非负整数,如果是负数则返回 `None`。 ### 回答2: 计算一个正整数的正平方根可以使用牛顿迭代法来实现。牛顿迭代法是一种不断逼近目标值的方法,可以用来解方程的根。 以下是使用牛顿迭代法计算正整数的正平方根的源码示例: ```python def sqrt(x): if x < 0: return None # 输入错误,返回None guess = x # 初始猜测值为x while True: sqrt = (guess + x / guess) / 2 # 使用牛顿迭代法得到新的猜测值 if abs(sqrt - guess) < 1e-6: # 判断新的猜测值是否足够接近 return sqrt guess = sqrt # 测试示例 num = 16 result = sqrt(num) if result is not None: print("正整数{}的正平方根为{}".format(num, result)) else: print("输入错误") ``` 以上源码通过不断迭代解,逼近正整数的正平方根。在每一轮迭代中,利用牛顿迭代法的公式更新猜测值,直到新的猜测值与上一轮的猜测值之差小于设定的精度阈值(这里设为1e-6)。最后返回正整数的正平方根或者None(如果输入错误)。 示例中测试了计算正整数16的正平方根的结果,并进行了相应的输出。您可以根据需要修改num的值来测试其他正整数的正平方根计算结果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值