【C语言】pow、sqrt函数的模拟实现

简介: pow、sqrt函数的模拟实现

一. 函数介绍

pow(x, y) —— 求x的y次方

sqrt(x) — 求x的算数平方根

二. pow函数模拟实现

普通版:递减n的大小,逐次乘num。


#include<stdio.h>
double MyPow(double num, int n)
{
  if (n < 0)
  return 1.0 / MyPow(num, -n);
  else if (n == 0)
  return 1.0;
  else if (n > 0)
  return num * MyPow(num, n - 1);
}
int main()
{
  printf("%lf\n", my_pow(2,-2));
  return 0;
}


优化版:依据n的奇偶性分情况进行递归处理。

#include<stdio.h>
double MyPow(double num, int n)
{
  if (n < 0)
  return 1.0 / MyPow(num, -n);
  else if (n == 0)
  return 1.0;
  else if (n > 0)
  {
  double tmp = MyPow(num, n / 2);
  if (0 == (n%2)// n为偶数时
    return tmp * tmp;
  else// n为奇数时
    return num*tmp*tmp;
  }
}
int main()
{
  printf("%lf\n", my_pow(2,-2));
  return 0;
}



运行结果


20210203192538296.png

三. sqrt函数模拟实现

使用二分查找1~x范围内平方小于x的最大的数就是最终结果


int mySqrt(int x) 
{
    int left = 1;
    int right = x;
    int ret = 0;
    while(left <= right)
    {
        int mid = left + (right-left)/2;
        if(mid <= x/mid)
        {
            ret = mid;
            left = mid + 1;
        }
        else 
        {
            right = mid - 1;
        }
    }
    return ret;
}


相关文章
|
21天前
|
存储 编译器 C语言
爱上C语言:函数递归,青蛙跳台阶图文详解
爱上C语言:函数递归,青蛙跳台阶图文详解
|
21天前
|
编译器 程序员 C语言
爱上C语言:什么C语言函数不太会,那你千万不要错过这篇(函数篇)
爱上C语言:什么C语言函数不太会,那你千万不要错过这篇(函数篇)
|
7天前
|
C语言
C语言:内存函数(memcpy memmove memset memcmp使用)
C语言:内存函数(memcpy memmove memset memcmp使用)
|
1天前
|
缓存 安全 编译器
【C 言专栏】C 语言函数的高效编程技巧
【5月更文挑战第1天】本文探讨了C语言中函数的高效编程技巧,包括函数的定义与作用(如代码复用和提高可读性)、设计原则(单一职责和接口简洁)、参数传递方式(值传递、指针传递和引用传递)、返回值管理、调用约定、嵌套与递归调用,以及函数优化技巧和常见错误避免。掌握这些技巧能提升C语言代码的质量和效率。
【C 言专栏】C 语言函数的高效编程技巧
|
4天前
|
C语言
pta浙大版《C语言程序设计(第3版)》 习题6-4 使用函数输出指定范围内的Fibonacci数 (20分)
pta浙大版《C语言程序设计(第3版)》 习题6-4 使用函数输出指定范围内的Fibonacci数 (20分)
|
4天前
|
C语言
pta 浙大版《C语言程序设计(第3版)》题目集 习题6-6 使用函数输出一个整数的逆序数 (20分)
pta 浙大版《C语言程序设计(第3版)》题目集 习题6-6 使用函数输出一个整数的逆序数 (20分)
|
4天前
|
C语言
(浙大版《C语言程序设计(第3版)》 习题6-5 使用函数验证哥德巴赫猜想 (20分)
(浙大版《C语言程序设计(第3版)》 习题6-5 使用函数验证哥德巴赫猜想 (20分)
|
6天前
|
安全 C语言
【C语言】strcpy与strncpy函数的使用和模拟实现
【C语言】strcpy与strncpy函数的使用和模拟实现
5 0
|
6天前
|
C语言
【C语言】字符分类函数与字符转换函数
【C语言】字符分类函数与字符转换函数
9 1
|
6天前
|
程序员 编译器 C语言
C语言之函数与参数
C语言之函数与参数
5 0