C语言中四种取整方式,取余/取模运算以及负数取模问题详解

 更新时间:2021年09月07日 09:57:31   作者:精致的灰(>_<)  
这篇文章主要介绍了C语言中四种取整方式及负数取模问题,包括了算法的分析与改进,是很多程序设计竞赛中常见的算法,需要的朋友可以参考下

零向取整、负无穷向取整、正无穷向取整、四舍五入取整

如果将一个浮点数赋值给整形,只会保存整数位:

在这里插入图片描述

这种取整方式为零向取整,C语言默认采用的是这种方式

在这里插入图片描述

C语言中也有对应的零向取整函数:

在这里插入图片描述

在这里插入图片描述

同理还有一种函数是负无穷大取整:

在这里插入图片描述

在这里插入图片描述

它的取整方案是向负无穷大取整:

在这里插入图片描述

有地板取整,当然也有正无穷大取整的函数:

在这里插入图片描述

在这里插入图片描述

它的取整方式是向正无穷大取整:

在这里插入图片描述

最后,还有四舍五入取整的函数:

在这里插入图片描述

在这里插入图片描述

取模/取余

取模概念: 如果a和d是两个自然数,d非零,可以证明存在两个唯一的整数 q 和 r,满足 a = q*d + r 且0 ≤ r < d。其中,q 被称为商,r 被称为余数。所以q=a/d,r=a%d。

但是如果对负数取模呢?

在C语言中:

在这里插入图片描述

在Python中:

在这里插入图片描述

可以看到这两种取模结果是不一样的。

a=-10,d=3;
-10=(-3)*3+(-1)  q=-3,r=-1;  C语言
-10=(-4)*3+2  q=-4,r=2; Python

由上面的例子可以看出,具体余数r的大小,本质是取决于商q的。 而商取决于除法计算的时候的取整规则。

比如上面的-10/3=-3.3333,如果将商向零整,则结果为-3,此时余数为-1,而如果商向负无穷方向取整,则结果为-4,此时余数为2。

这两种取整方式,就是取模和取余的区别:

取余或者取模,都应该要算出商,然后才能得出余数。
取余:尽可能让商,进行向零取整。
取模:尽可能让商,向负无穷方向取整

这两种方式对于商是正数的情况没有区别,因为零向取整和负无穷方向取整的结果是一样的。但如果商的结果是负数,则取余和取模的结果是不一样的。

所以,参与取余的两个数据,如果同符号,取模等价于取余,因为商是正数,如果不同符号,则取模和取余不同。

在这里插入图片描述

综上,C语言中的%本质其实是取余,Python中的%本质是取模。

并且通过上面的分析,我们可以得出结论:

具体余数r的大小,本质是取决于商q的。而商,又取决于除法计算的时候,取整规则。
取余和取模: 取余尽可能让商,进行向零取整。取模尽可能让商,向负无穷方向取整。
参与取余的两个数据,如果同符号,取模等价于取余。
如果参与取余的两个数据符号不同,在C语言中(或者其他采用向0取整的语言如:C++,Java),余数符号,与被除数相同。(因为采用的向0取整)

总结

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

相关文章

  • C++实现LeetCode(132.拆分回文串之二)

    C++实现LeetCode(132.拆分回文串之二)

    这篇文章主要介绍了C++实现LeetCode(132.拆分回文串之二),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • 利用C语言实现简易版扫雷

    利用C语言实现简易版扫雷

    这篇文章主要为大家详细介绍了C语言实现简易版扫雷,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-02-02
  • C语言入门篇--初识指针和指针变量

    C语言入门篇--初识指针和指针变量

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

    C++this指针详情

    这篇文章主要介绍了C++this指针详情,在 C++ 中,每一个对象都能通过 this 指针来访问自己的地址。this 指针是所有成员函数的隐含参数。因此,在成员函数内部,它可以用来指向调用对象,下面我们来了解更多详细内容吧
    2022-01-01
  • 判断整数序列是否为二元查找树的后序遍历结果的解决方法

    判断整数序列是否为二元查找树的后序遍历结果的解决方法

    本篇文章是对判断整数序列是否为二元查找树的后序遍历结果的解决方法进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • 一篇文章彻底弄懂C++虚函数的实现机制

    一篇文章彻底弄懂C++虚函数的实现机制

    C++中的虚函数的作用主要是实现了多态的机制,基类定义虚函数,子类可以重写该函数,在派生类中对基类定义的虚函数进行重写时,需要在派生类中声明该方法为虚方法,这篇文章主要给大家介绍了关于如何通过一篇文章彻底弄懂C++虚函数的实现机制,需要的朋友可以参考下
    2021-06-06
  • C语言常见的文件操作函数

    C语言常见的文件操作函数

    这篇文章主要为大家介绍了C语言文件操作函数,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • C语言可变参数函数详解

    C语言可变参数函数详解

    在某些情况下我们希望函数的参数个数可以根据需要确定,因此c语言引入可变参数函数。典型的可变参数函数的例子有printf()、scanf()等,下面我就开始讲解
    2021-08-08
  • 深入浅出分析C++ string底层原理

    深入浅出分析C++ string底层原理

    C ++的string对象实质上就是一个容器,其内部有一个c_str方法能够返回一个指向的实质存储字符串副本的数据成员。即通过string::c_str()配合printf函数可以获取的字符串副本的内存地址
    2021-11-11
  • c++详细讲解构造函数的拷贝流程

    c++详细讲解构造函数的拷贝流程

    拷贝构造函数是一种特殊的构造函数,它在创建对象时,是使用同一类中之前创建的对象来初始化新创建的对象。拷贝构造函数通常用于:通过使用另一个同类型的对象来初始化新创建的对象。 复制对象把它作为参数传递给函数。复制对象,并从函数返回这个对象
    2022-05-05

最新评论