详细解析C语言中的开方实现

 更新时间:2015年08月07日 17:27:39   作者:zinss26914  
这篇文章主要介绍了详细解析C语言中的开方实现,包括一道要求精度的整数开方的题目,需要的朋友可以参考下

关于C语言中的开方计算,首先想到的当然是sqrt()函数,让我们先来回顾一下它的基本用法:
头文件:#include <math.h>

sqrt() 用来求给定值的平方根,其原型为:

  double sqrt(double x);

参数

x 为要计算平方根的值。

如果 x < 0,将会导致 domain error 错误,并把全局变量 errno 的值为设置为 EDOM。

返回值

返回 x 平方根。

注意,使用 GCC 编译时请加入-lm。

实例计算200 的平方根值。

#include <math.h>
main(){
  double root;
  root = sqrt(200);
  printf("answer is %f\n", root);
}

输出结果:
answer is 14.142136

题目
求整数N的开方,精度在0.001

二分法
若N大于1,则从[1, N]开始,low = 1, high = N, mid = low + (high - low) >> 1开始进行数值逼近

若N小于1,则从[N, 1]开始,low = 0, high = N, mid = low + (high - low) >> 1开始进行数值逼近

ac代码


 /** 
   * 创新工厂2014年校招算法题目,求整数N的开方,精度为0.001 
   */ 
   
  #include <stdio.h> 
  #include <stdlib.h> 
  #include <math.h> 
   
  #define ACCURACY 0.001 
   
  double newSqrt(double n) 
  { 
    double low, high, mid, tmp; 
   
    // 获取上下界 
    if (n > 1)  { 
      low = 1; 
      high = n; 
    } else { 
      low = n; 
      high = 1; 
    } 
   
    // 二分法求开方 
    while (low <= high) { 
      mid = (low + high) / 2.000; 
   
      tmp = mid * mid; 
   
      if (tmp - n <= ACCURACY && tmp -n >= ACCURACY * -1) { 
        return mid; 
      } else if (tmp > n) { 
        high = mid; 
      } else { 
        low = mid; 
      } 
    } 
   
    return -1.000; 
  } 
   
  int main(void) 
  { 
    double n, res; 
   
    while (scanf("%lf", &n) != EOF) { 
      res = newSqrt(n); 
      printf("%lf\n", res); 
    } 
   
    return 0; 
  } 

相关文章

  • VC取得任务栏高度的方法

    VC取得任务栏高度的方法

    这篇文章主要介绍了VC取得任务栏高度的方法,需要的朋友可以参考下
    2014-07-07
  • opencv实现图像颜色空间转换

    opencv实现图像颜色空间转换

    这篇文章主要为大家详细介绍了opencv实现图像颜色空间转换,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-08-08
  • C语言实现猜数字的小游戏

    C语言实现猜数字的小游戏

    这篇文章主要为大家详细介绍了C语言实现猜数字的小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-01-01
  • C++中的类扩展之继承和组合详解

    C++中的类扩展之继承和组合详解

    在C++中,类扩展可以通过继承、组合和装饰模式实现。继承可以实现对已有类的修改和扩展,组合可以增加新的功能,装饰模式则能够在不改变原类的情况下为其添加新的功能。这些技术在C++程序设计中应用广泛,提高了程序的可扩展性和可维护性
    2023-04-04
  • C++程序函数的重载和函数模板示例代码

    C++程序函数的重载和函数模板示例代码

    C++允许在同一作用域中用同一函数名定义多个函数,这些函数的参数个数和参数类型不相同,这些同名的函数用来实现不同的功能,这就是函数的重载,这篇文章主要介绍了C++程序函数的重载和函数模板,需要的朋友可以参考下
    2024-03-03
  • C++详解PIMPL指向实现的指针

    C++详解PIMPL指向实现的指针

    PIMPL 是 C++ 中的一个编程技巧,意思为指向实现的指针。具体操作是把类的实现细节放到一个单独的类中,并用一个指针进行访问
    2022-07-07
  • C语言 小游戏打砖块实现流程详解

    C语言 小游戏打砖块实现流程详解

    打砖块游戏是一种动作电子游戏的名称。玩家操作一根萤幕上水平的“棒子”,让一颗不断弹来弹去的“球”在撞击作为过关目标消去的“砖块”的途中不会落到萤幕底下。球碰到砖块、棒子与底下以外的三边会反弹,落到底下会失去一颗球,把砖块全部消去就可以破关
    2021-11-11
  • C++中的Primer拷贝、赋值与销毁详解

    C++中的Primer拷贝、赋值与销毁详解

    这篇文章主要介绍了C++中的Primer拷贝、赋值与销毁方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-03-03
  • C++ sleep()和usleep()的区别

    C++ sleep()和usleep()的区别

    本文主要介绍了C++ sleep()和usleep()的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • c++显式栈实现递归介绍

    c++显式栈实现递归介绍

    大家好,本篇文章主要讲的是c++显式栈实现递归介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-01-01

最新评论