c语言中fmod,C语言中 %与fmod()在计算余数时的区别与联系

本文详细介绍了C++中整数运算符%和数学函数fmod()在计算余数时的区别。%运算符仅适用于整数且不支持除数为0,结果保持原数符号;而fmod()函数可以处理浮点数,能处理除数为0的情况,返回值符号与第一个参数一致。通过多个示例展示了两者的不同用法和计算结果。
摘要由CSDN通过智能技术生成

%与fmod()在计算余数时的区别与联系

一、% 运算符

% 只用于整型的计算,后一个数不能是0,参与运算的数据可正可负。

对于x%y ,计算之后结果的正负与x的符号相同,如果前者是较小的数,后者是较大的数,那么,结果直接为较小的数。

例如:

10%3=1

3%10=3

10%-3=1

-3%10=-3

-10%-3=-1

-3%-10=-3

3%13=3

0%3=0

0%-3=0

3%0  (×)Error!

-3%0  (×)Error!

10.0%3.0 (×)Error!浮点型不能进行模运算

二、fmod()函数

fmod()函数包含于math.h头文件中,它可以对浮点型数据进行取模运算

这是它的原型 double fmod(double x,double y)

fmod()函数没有%那样的要求,后一个数可为0,这时函数返回NaN

当参数为小数是,会进行如下运算:

返回值 = x-n×y

其中n=x÷y ,并向离开0的方向取整

计算后结果的符号与前者(x)相同,如果前者是较小的数,后者是较大的数,那么结果直接为较小的数。

例如:

float x=10.0;

float y=-3.0;

float z=3.0;

result=fmod(x,z);   //应用 double fmod(double x,double y) 求浮点型的余数

printf("10.0%%3.0= %f/n",result); //1.0

result=fmod(z,x);

printf("3.0%%10.0= %f/n",result); //3.0

result=fmod(x,y);

printf("10.0%%-3.0= %f/n",result); //1.0

result=fmod(y,x);

printf("-3.0%%10.0= %f/n",result); //-3.0

result=fmod(0,z);

printf("0.0%%3.0= %f/n",result); //0.0

result=fmod(0,y);

printf("0.0%%-3.0= %f/n",result); //0.0

result=fmod(3,13);

printf("3%%-13= %f/n",result);  //3

result=fmod(10.1,3.1);

printf("10.1%%3.1= %f/n",result); //0.8

result=fmod(10.9,3.9);

printf("10.9%%3.9= %f/n",result); //3.1

result=fmod(10.9,-3.9);

printf("10.9%%-3.9= %f/n",result); //3.1

result=fmod(-10.9,3.9);

printf("-10.9%%3.9= %f/n",result); //-3.1

result=fmod(-10.9,-3.9);

printf("-10.9%%-3.9= %f/n",result); //-3.1

result=fmod(-10.9,12);

printf("-10.9%%12= %f/n",result); //-10.9

转自:http://m.blog.csdn.net/blog/nista/5903582

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值