C++中的取余函数remainder与fmod详解

 更新时间:2023年05月25日 11:12:33   作者:gsgbgxp  
这篇文章主要为大家详细介绍了C++中的取余函数remainder、fmod的具体使用以及自编的remainder及fmod,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习学习

1.整数取余

%

2.remainder函数

用法:

double remainder (double numer , double denom);
float remainder (float numer , float denom);
long double remainder (long double numer, long double denom);
double remainder (Type1 numer , Type2 denom); // additional overloads

Returns the floating-point remainder of numer/denom (rounded to nearest):

remainder = numer - rquot * denom

Where rquot is the result of: numer/denom, rounded toward the nearest integral value (with halfway cases rounded toward the even number).

A similar function, fmod, returns the same but with the quotient truncated (rounded towards zero) instead.

The function remquo has a behavior identical to this function, but it additionally provides access to the intermediate quotient value used.

Additional overloads are provided in this header () for other combinations of arithmetic types (Type1 and Type2): These overloads effectively cast its arguments to double before calculations, except if at least one of the arguments is of type long double (in which case both are casted to long double instead).

Parameters

numer: Value of the quotient numerator.
denom: Value of the quotient denominator.

Return Value

The remainder of dividing the arguments.
If this remainder is zero, its sign shall be that of numer.
If denom is zero, the function may either return zero or cause a domain error (depending on the library implementation).

If a domain error occurs:

And math_errhandling has MATH_ERRNO set: the global variable errno is set to EDOM.
And math_errhandling has MATH_ERREXCEPT set: FE_INVALID is raised.

示例:

/* remainder example */
#include <stdio.h>      /* printf */
#include <math.h>       /* remainder */
int main ()
{
  printf ( "remainder of 5.3 / 2 is %f\n", remainder (5.3,2) );
  printf ( "remainder of 18.5 / 4.2 is %f\n", remainder (18.5,4.2) );
  return 0;
}

输出:

remainder of 5.3 / 2 is -0.700000
remainder of 18.5 / 4.2 is 1.700000

3.fmod函数

https://cplusplus.com/reference/cmath/fmod/?kw=fmod

用法:

double fmod (double numer , double denom); float fmod (float numer , float denom);long double fmod (long double numer, long double denom); double fmod (Type1 numer , Type2 denom); // additional overloads

Compute remainder of division

Returns the floating-point remainder of numer/denom (rounded towards zero):

fmod = numer - tquot * denom

Where tquot is the truncated (i.e., rounded towards zero) result of: numer/denom.

A similar function, remainder, returns the same but with the quotient rounded to the nearest integer (instead of truncated).

Additional overloads are provided in this header () for other combinations of arithmetic types (Type1 and Type2): These overloads effectively cast its arguments to double before calculations, except if at least one of the arguments is of type long double (in which case both are casted to long double instead).

Parameters

numer Value of the quotient numerator. denom Value of the quotient
denominator.

Return Value

The remainder of dividing the arguments.
If denom is zero, the function may either return zero or cause a domain error (depending on the library implementation).

C90 (C++98)C99 (C+11)

If a domain error occurs:

  • And math_errhandling has MATH_ERRNO set: the global variable errno is set to EDOM.
  • And math_errhandling has MATH_ERREXCEPT set: FE_INVALID is raised.

示例:

/* fmod example */
#include <stdio.h>      /* printf */
#include <math.h>       /* fmod */
int main ()
{
  printf ( "fmod of 5.3 / 2 is %f\n", fmod (5.3,2) );
  printf ( "fmod of 18.5 / 4.2 is %f\n", fmod (18.5,4.2) );
  return 0;
}

输出:

fmod of 5.3 / 2 is 1.300000
fmod of 18.5 / 4.2 is 1.700000

4.自编remainder及fmod

#include <iostream>
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
using namespace std;
//VS2010不提供remainder这个函数,自己实现
//http://www.cplusplus.com/reference/cmath/remainder/
//Returns the floating - point remainder of numer / denom(rounded to nearest) :
//remainder = numer - rquot * denom
//Where rquot is the result of : numer / denom, rounded toward the nearest integral value(with halfway cases rounded toward the even number).
//A similar function, fmod, returns the same but with the quotient truncated(rounded towards zero) instead.
#define ROUND(d)  int(d + 0.5)//四舍五入
double myremainder(double numer, double denom)
{
	//如果一正一负,这个函数结果可能不对
	int rquot = ROUND(numer / denom);//remainder和fmod的区别就是要不要四舍五入
	double remainder = numer - rquot * denom;
	return remainder;
}
double myfmod(double x, double y)
{
	return x - (int)(x / y) * y;
}
int main()
{
	double x, y;
	x = 14.3;
	y = 3.0;
	printf("x = %f, y = %f\n", x, y);
	printf("remainder(x, y) = %f\n", remainder(x, y)); // 计算余数,四舍五入到最接近的整数
	printf("myremainder(x, y) = %f\n", myremainder(x, y)); // 计算余数,四舍五入到最接近的整数
	printf("fmod(x, y) = %f\n", fmod(x, y)); // 计算余数,向零取整
	printf("myfmod(x, y) = %f\n", myfmod(x, y)); // 计算余数,向零取整
	x = -14.3;
	y = 3.0;
	printf("x = %f, y = %f\n", x, y);
	printf("remainder(x, y) = %f\n", remainder(x, y)); // 计算余数,四舍五入到最接近的整数
	printf("myremainder(x, y) = %f\n", myremainder(x, y)); // 计算余数,四舍五入到最接近的整数
	printf("fmod(x, y) = %f\n", fmod(x, y)); // 计算余数,向零取整
	printf("myfmod(x, y) = %f\n", myfmod(x, y)); // 计算余数,向零取整
	x = 14.3;
	y = -3.0;
	printf("x = %f, y = %f\n", x, y);
	printf("remainder(x, y) = %f\n", remainder(x, y)); // 计算余数,四舍五入到最接近的整数
	printf("myremainder(x, y) = %f\n", myremainder(x, y)); // 计算余数,四舍五入到最接近的整数
	printf("fmod(x, y) = %f\n", fmod(x, y)); // 计算余数,向零取整
	printf("myfmod(x, y) = %f\n", myfmod(x, y)); // 计算余数,向零取整
	x = -14.3;
	y = -3.0;
	printf("x = %f, y = %f\n", x, y);
	printf("remainder(x, y) = %f\n", remainder(x, y)); // 计算余数,四舍五入到最接近的整数
	printf("myremainder(x, y) = %f\n", myremainder(x, y)); // 计算余数,四舍五入到最接近的整数
	printf("fmod(x, y) = %f\n", fmod(x, y)); // 计算余数,向零取整
	printf("myfmod(x, y) = %f\n", myfmod(x, y)); // 计算余数,向零取整
	system("pause");
}

输出结果

到此这篇关于C++中的取余函数remainder与fmod详解的文章就介绍到这了,更多相关C++取余内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 带你粗略了解C++回文链表

    带你粗略了解C++回文链表

    这篇文章主要介绍了Python实现的判断回文链表算法,结合实例形式分析了Python针对链表是否为回文链表进行判断的相关算法实现技巧,需要的朋友可以参考下
    2021-08-08
  • C++ 空指针解引用的解决方法

    C++ 空指针解引用的解决方法

    空指针解引用是一种常见且严重的错误,它通常由于指针未初始化、被设置为nullptr或指向无效地址引起,本文主要介绍了C++ 空指针解引用的解决方法,感兴趣的可以了解一下
    2024-08-08
  • C语言实现简易通讯录(静态版本)的代码分享

    C语言实现简易通讯录(静态版本)的代码分享

    这篇文章主要为大家详细介绍了如何录音C语言实现一个简易的通讯录(静态版本),文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-10-10
  • C语言 超详细讲解算法的时间复杂度和空间复杂度

    C语言 超详细讲解算法的时间复杂度和空间复杂度

    算法复杂度分为时间复杂度和空间复杂度。其作用: 时间复杂度是度量算法执行的时间长短;而空间复杂度是度量算法所需存储空间的大小
    2022-03-03
  • 一篇文章带你了解C语言指针进阶

    一篇文章带你了解C语言指针进阶

    这篇文章主要介绍了C语言指针详解及用法示例,介绍了其相关概念,然后分享了几种用法,具有一定参考价值。需要的朋友可以了解下
    2021-09-09
  • C++实现图形界面时钟表盘代码

    C++实现图形界面时钟表盘代码

    这篇文章主要介绍了C++实现图形界面时钟表盘代码,涉及坐标函数的应用及图形界面程序设计,需要的朋友可以参考下
    2014-10-10
  • OpenCV实现车牌定位(C++)

    OpenCV实现车牌定位(C++)

    这篇文章主要为大家详细介绍了OpenCV实现车牌定位,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-11-11
  • C语言入门篇--变量的左值和右值

    C语言入门篇--变量的左值和右值

    本篇文章是基础篇,适合c语言刚入门的朋友,本文对初识c语言的指针和指针变量做了简单的分析,帮助大家快速入门c语言的世界,更好的理解c语言
    2021-08-08
  • C++ TensorflowLite模型验证的过程详解

    C++ TensorflowLite模型验证的过程详解

    这篇文章给大家介绍了C++ TensorflowLite模型验证的过程,测试代码,主要是RunInference()和read_file(),详细操作过程跟随小编一起看看吧
    2021-08-08
  • QT使用udp实现发送与接收图片

    QT使用udp实现发送与接收图片

    这篇文章主要为大家详细介绍了QT如何使用udp协议实现发送与接收图片功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2023-12-12

最新评论