原文:http://blog.csdn.net/legend050709/article/details/39394381

sqrt算法实现:

(一)int sqrt1(int n);
求取整数x的平方根,向下取整;

(0)步骤:

1.先求出范围;然后排序
2.然后二分查找;

(1)方法一:O(n)

for(int i=0;i*i<n;i++);
i=i-1;

(2)方法二:二分查找,O(lgn)

1)范围已经确定,即0~n,并且0~n之间的数据有序;
2)二分查找:

int sqrt1(int n){
 int left=0;
 int right=n;
 int mid;
 int last;
 while(left<=right){//应该找出mid*mid<=n的最后一个数
  mid=(right-left)/2+left;

if(mid*mid<=n){//寻找最后一个数,所以不断压缩左边,即left=mid+1
   last=mid;
   left=mid+1;
  }else{
   right=mid-1;
  }
 }
return last;
}

(3)方法三:O(lg(2分之根号n))+lg(根号n)

1)先确定范围;O(lg(2分支根号n))

for(int i=n;i*i>n;i=i/2);
j=2*i;

循环结束时,i*i<=n<(2i)*(2i)即i^2<=n<4i^2
然后只需要在i~2i之间寻找一个最大的数k,是的k^2<=n。

2)二分查找:

int left=i,right=j;

while(left<=right){//应该找出mid*mid<=n的最后一个数
  mid=(right-left)/2+left;

if(mid*mid<=n){//寻找最后一个数,所以不断压缩左边,即left=mid+1
   last=mid;
   left=mid+1;
  }else{
   right=mid-1;
  }
 }
return last;

----------------------

(二)float sqrt(float x)库函数的实现:
(1)二分法:

const float eps=0.000001; // eps的值可能影响最后计算精度,甚至导致无限循环
// 二分法,注意区分x的取值区间
float SqrtByBisection(float x)
{
 if(x<0) // 负数
  return x;
 if(x<=eps) // 正数0
  return 0.0f;
 if(fabs(x-1)<=eps) // 正数1
  return 1.0f;
 float left, right;
 float mid;
 if(x>eps&&x<1.0f-eps) // (0,1)区间
 {
  left=x;
  right=1.0f;
 } 
 else
 {
  left=1.0f;
  right=x;
 }  
 while(right-left>eps) // (1,)区间
 {
  mid=(left+right)/2;
  if(mid*mid>x+eps)
   right=mid;
  else if(mid*mid<x-eps)
   left=mid;
  else
   return mid;
 } 
 return mid;
}

---
(2)牛顿迭代算法:

1)示例图如下:
图一,图二:

2)代码实现:

// 牛顿迭代法
const float eps=0.000001; // eps的值可能影响最后计算精度,甚至导致无限循环
float SqrtByNewton(float x)
{
 float val=x;
 float last;
 while(fabs(val-last)>eps)
 {
  last=val;
  val=(val+x/val)/2;
 }
 return val;
}

----

(3)性能最好:比标准库函数快4倍;(不需要理解,了解即可)

float InvSqrt(float x)
{
 float xhalf = 0.5f*x;
 int i = *(int*)&x; // get bits for floating VALUE 
 i = 0x5f375a86- (i>>1); // gives initial guess y0
 x = *(float*)&i; // convert bits BACK to float
 x = x*(1.5f-xhalf*x*x); // Newton step, repeating increases accuracy
 x = x*(1.5f-xhalf*x*x); // Newton step, repeating increases accuracy
 x = x*(1.5f-xhalf*x*x); // Newton step, repeating increases accuracy

return 1/x;
}

sqrt函数的实现的更多相关文章

  1. 转:一个Sqrt函数引发的血案

    转自:http://www.cnblogs.com/pkuoliver/archive/2010/10/06/1844725.html 源码下载地址:http://diducoder.com/sotr ...

  2. [转载]求平方根sqrt()函数的底层算法效率问题

    我们平时经常会有一些数据运算的操作,需要调用sqrt,exp,abs等函数,那么时候你有没有想过:这个些函数系统是如何实现的?就拿最常用的sqrt函数来说吧,系统怎么来实现这个经常调用的函数呢? 虽然 ...

  3. Sqrt函数高效实现

    转自一个Sqrt函数引发的血案 我们平时经常会有一些数据运算的操作,需要调用sqrt,exp,abs等函数,那么时候你有没有想过:这个些函数系统是如何实现的?就拿最常用的sqrt函数来说吧,系统怎么来 ...

  4. 一个Sqrt函数引发的血案(转)

    作者: 码农1946  来源: 博客园  发布时间: 2013-10-09 11:37  阅读: 4556 次  推荐: 41   原文链接   [收藏]   好吧,我承认我标题党了,不过既然你来了, ...

  5. 【转载】一个Sqrt函数引发的血案

    转自:http://www.cnblogs.com/pkuoliver/archive/2010/10/06/sotry-about-sqrt.html 源码下载地址:http://diducoder ...

  6. 一个Sqrt函数引发的血案

    源码下载地址:http://diducoder.com/sotry-about-sqrt.html 好吧,我承认我标题党了,不过既然你来了,就认真看下去吧,保证你有收获. 我们平时经常会有一些数据运算 ...

  7. sqrt函数实现(神奇的算法)

    我们平时经常会有一些数据运算的操作,需要调用sqrt,exp,abs等函数,那么时候你有没有想过:这个些函数系统是如何实现的?就拿最常用的sqrt函数来说吧,系统怎么来实现这个经常调用的函数呢? 虽然 ...

  8. php sqrt()函数 语法

    php sqrt()函数 语法 作用:sqrt()函数的作用是对参数进行求平方根 语法:sqrt(X) 参数: 参数 描述 X 进行求平方根的数字 说明:返回将参数X进行开平方后的结果江苏大理石平台 ...

  9. PHP sqrt() 函数

    实例 返回不同数的平方根: <?phpecho(sqrt(0) . "<br>");echo(sqrt(1) . "<br>"); ...

  10. sqrt函数实现

    感谢杨工,让我更加认识到自己技术薄弱,这道题源自于和杨工的非正式面试,当时根本没思路,甚至没和查找有丝毫的联系,看来做自己想做的还是要付出努力的.sqrt()即开平方运算,y=x*x,已知Y的情况下求 ...

随机推荐

  1. spring cloud 学习(1) - 基本的SOA示例

    有过dubbo/dubbox使用经验的朋友,看到下面这张图,一定很熟悉,就是SOA架构的最基本套路. 与dubbo对比,上图的3大要素中,spring cloud是借助以下组件来实现的: 1.注册中心 ...

  2. HDU 4747 Mex (2013杭州网络赛1010题,线段树)

    Mex Time Limit: 15000/5000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Total Submis ...

  3. mongodb chunk 大小设置

    默认是64MB,取值范围是1 MB 到 1024 MB. 那改动会造成什么?下表简单总结: chunk size 调节 splitting次数(碎片数) 数据跨shard数目 数据均匀 网络传输次数 ...

  4. spy++使用指南

    很多朋友都对窗口句柄比较迷糊,这篇短文就以spy++这个软件为主,介绍下窗体句柄和使用按键插件时,如果对这个句柄发送消息,即所谓的后台挂机.spy++这个软件来自VC++,装好VC后,就可以在工具中看 ...

  5. Snmp学习总结(五)——WindowsServer2008安装和配置SNMP

    一.安装SNMP 在Windows Server 2008以及Windows Server 2008 R2中,SNMP是以一个服务器功能的形式存在的,SNMP的安装步骤如下所示: 1.打开[开始]→[ ...

  6. Android基础笔记(九)- 广播

    广播的概念 广播的生命周期 案例-监听短信到来并解析短信内容 案例-拦截外拨电话并设置区号 案例-SD卡状态监听 介绍一些经常使用的广播 发送自己定义广播 有序广播和无序广播 启程!! ! 广播的概念 ...

  7. 架构:Screaming Architecture(转载)

    Imagine that you are looking at the blueprints of a building. This document, prepared by an architec ...

  8. Unity动画知识之二:Animator动画状态机

    上次我们讲过Unity游戏动画从入门到住院,今天我们来讲一下动画状态机. 好了,现在我们已经成功的导入了动画.接下来要玩的东西就很装13啦.因为大部分动画师是用不到这家伙的,需要掌握这个技能的,至少也 ...

  9. 朽木第一至三季/全集Deadwood迅雷下载

    英文译名Deadwood,第1-3季(2004-2006)HBO. 本季看点:<朽木>又名<死木>由<纽约重案组>(NYPD Blue)制作人大卫·米奇担纲,讲述美 ...

  10. osx升级到10.10后,使用pod install报错解决的方法

    先看下网上的解决方法例如以下: 先依照这个文章做:http://blog.csdn.net/dqjyong/article/details/37958067 大概过程例如以下: Open Xcode ...