• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > 详细解析C语言中的开方实现

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

作者:zinss26914 字体:[增加 减小] 来源:互联网 时间:2017-05-28

zinss26914 通过本文主要向大家介绍了c语言开方,c语言开方函数,c语言开方怎么表示,c语言中开方怎么表示,c语言开方程序等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

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

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

  double sqrt(double x);
</div>

参数

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);
}
</div>

输出结果:
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; 
  } 
</div>

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

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

相关文章

  • 2017-05-28C语言中全局数组和局部数组的问题
  • 2017-05-28iostream与iostream.h的区别详细解析
  • 2017-05-28C++ 中重载和运算符重载加号实现矩阵相加实例代码
  • 2017-05-28Assert(断言实现机制深入剖析)
  • 2017-05-28c++非变易算法-stl算法
  • 2017-05-28C++使用递归方法求n阶勒让德多项式完整实例
  • 2017-05-28C++ 多重继承和虚拟继承对象模型、效率分析
  • 2017-05-28linux c多线程编程实例代码
  • 2017-08-30c语言中指针大小以及使用初始化问题
  • 2017-05-28c++验证哥德巴赫猜想

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 关于C/C++中typedef的定义与用法总结
    • 浅析C/C++变量在内存中的分布
    • 浅谈带缓冲I/O 和不带缓冲I/O的区别与联系
    • C++实现ping程序实例
    • VC实现批量删除指定文件的方法
    • C语言 结构体和指针详解及简单示例
    • jquery ready函数深入分析
    • 利用c语言实现卷积码编码器示例
    • C++中事件机制的简洁实现及需要放弃的特性
    • 浅析C语言编程中的数组越界问题

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有