C语言编程深入理解取整取余取模问题示例分析

 更新时间:2021年11月24日 14:50:07   作者:鹿九丸  
这篇文章主要为大家介绍了C语言编程深入理解取整取余取模问题的示例分析详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步

1. 取整问题

1.0向取整(C语言默认的取整方案)

#include<stdio.h>
#include<windows.h>
int main()
{
	//本质是向0取整
   //trunc()函数也有这种作用,不过返回值是浮点数,而且必须引用math.h头文件
	int i = -2.9;
	int j = 2.9;
	printf("%d\n", i); //结果是:-2
	printf("%d\n", j); //结果是:2
	system("pause");
	return 0;
}

2.地板取整(向负无穷的方向取整)

#include <stdio.h>
#include <math.h> //因为使用了floor函数,需要添加该头文件
#include <windows.h>
int main()
{
	//本质是向-∞取整,注意输出格式要不然看不到结果
	printf("%.1f\n", floor(-2.9)); //-3
	printf("%.1f\n", floor(-2.1)); //-3
	printf("%.1f\n", floor(2.9)); //2
	printf("%.1f\n", floor(2.1)); //2
	system("pause");
	return 0;
}

 注意:

使用floor()函数需要引头文件,参数为double 类型。返回值也同样为double类型。

同时不要忘了引math.h头文件。

 注意:python默认的取整方案就是地板取整,后面也正是因为这个原因,才出现了取模的不同!

3.天花板取整(向+无穷的方向取整)

#include <stdio.h>
#include <math.h>
#include <windows.h>
int main()
{
	//本质是向+∞取整,注意输出格式要不然看不到结果
	printf("%.1f\n", ceil(-2.9)); //-2
	printf("%.1f\n", ceil(-2.1)); //-2
	printf("%.1f\n", ceil(2.9)); //3
	printf("%.1f\n", ceil(2.1)); //3
	system("pause");
	return 0;
}

注意:

使用ceil()函数需要引头文件,参数为double 类型。

返回值也同样为double类型。同时不要忘了引math.h头文件。

4.四舍五入取整

#include <stdio.h>
#include <math.h>
#include <windows.h>
int main()
{
//本质是四舍五入
printf("%.1f\n", round(2.1));
printf("%.1f\n", round(2.9));
printf("%.1f\n", round(-2.1));
printf("%.1f\n", round(-2.9));
system("pause");
return 0;
}

注意:使用round()函数需要引头文件,参数为double 类型。返回值也同样为double类型。同时不要忘了引math.h头文件。

汇总例子

#include <stdio.h>
#include <math.h>
#include <windows.h>
int main()
{
	const char* format = "%.1f \t%.1f \t%.1f \t%.1f \t%.1f\n";
	printf("value\tround\tfloor\tceil\ttrunc\n");
	printf("-----\t-----\t-----\t----\t-----\n");
	printf(format, 2.3, round(2.3), floor(2.3), ceil(2.3), trunc(2.3));
	printf(format, 3.8, round(3.8), floor(3.8), ceil(3.8), trunc(3.8));
	printf(format, 5.5, round(5.5), floor(5.5), ceil(5.5), trunc(5.5));
	printf(format, -2.3, round(-2.3), floor(-2.3), ceil(-2.3), trunc(-2.3));
	printf(format, -3.8, round(-3.8), floor(-3.8), ceil(-3.8), trunc(-3.8));
	printf(format, -5.5, round(-5.5), floor(-5.5), ceil(-5.5), trunc(-5.5));
	system("pause");
	return 0;
}

2.取模问题 

1.余数的定义

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

注意:余数并不一定都是正数,大家一定要牢记这个概念!

2.两种余数

由定义可知:

-10%3=-1------>-10/3=-3------->3*(-3)+(-1)=(-10)(C语言中是这样的)

-10%3=2------->-10/3=-4------->4*(-3)+ 2=(-10)(python环境中是这样的)

解释C: -10 = (-3) * 3 + (-1)(负余数)

解释Python:-10 = (?)* 3 + 2,其中,可以推到出来,'?'必须是-4

即-10 = (-4)* 3 + 2,才能满足定义。(正余数)

所以,在不同语言,同一个计算表达式,负数“取模”结果是不同的。我们可以称之为分别叫做正余数和负余数。

3.为什么会有这种现象?

由上面的例子可以看出,具体余数r的大小,本质是取决于商q的。

而商,又取决谁呢?取决于除法计算的时候,取整规则。

C语言中默认是0向取整,python中默认是-无穷的方向取整。

3.区分取余与取模

1.取余与与取模的本质区别

取余:尽可能让商,进行向0取整。

取模:尽可能让商,向负无穷方向取整。

所以:

C中%,本质其实是取余。

Python中%,本质其实是取模。

2.理解链

对任何一个大于0的数,对其进行0向取整和负无穷取整,取整方向是一致的。故取模等价于取余。其实这也是为什么我们常常会认为取模以取余是一码事的原因所在。

对任何一个小于0的数,对其进行0向取整和负无穷取整,取整方向是相反的。故取模不等价于取余。

3.同符号与不同符号

1.同符号:

同符号数据相除,得到的商,一定是正数,即大于0! 故,在对其商进行取整的时候,取模等价于取余。(倘若从数学上理解,就是简单的在负数的前面加一个绝对值即可)

2.不同符号

#include<stdio.h>
#include <windows.h>
int main()
{
	printf("%d\n", -10 / 3); //结果:-3
	printf("%d\n\n", -10 % 3); //结果:-1 为什么? -10=(-3)*3+(-1)
	printf("%d\n", 10 / -3); //结果:-3
	printf("%d\n\n", 10 % -3); //结果:1 为什么?10=(-3)*(-3)+1
	system("pause");
	return 0;
}

从上面可以看出:

被除数为负数时,取余后为负号。

除数为负数时,取余后为正数。

不同符号在C语言中虽然也有一定的规律,但我并不希望大家利用这个规律,而是利用定义老老实实的计算,毕竟这这是针对C语言的结论,在python中就不适用了,因为二者的取整方式是不同的。

以上就是C语言编程深入理解取整取余取模问题示例分析的详细内容,更多关于C语言取整取余取模问题的资料请关注脚本之家其它相关文章!

相关文章

  • 深入解析设计模式中的适配器模式在C++中的运用

    深入解析设计模式中的适配器模式在C++中的运用

    这篇文章主要介绍了设计模式中的适配器模式在C++中的运用,通常适配器模式可以细分为类适配器和对象适配器两种情况,需要的朋友可以参考下
    2016-03-03
  • Opencv透视变换综合实例详解

    Opencv透视变换综合实例详解

    这篇文章主要为大家详细介绍了Opencv透视变换综合实例,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-05-05
  • 适合初学者的C语言转义字符讲解

    适合初学者的C语言转义字符讲解

    转义字符是很多程序语言、数据格式和通信协议的形式文法的一部分。对于一个给定的字母表,一个转义字符的目的是开始一个字符序列,使得转义字符开头的该字符序列具有不同于该字符序列单独出现(没有转义字符开头)时的语义。因此转义字符开头的字符序列被叫做转义序列
    2022-04-04
  • 关于"引用"的几点说明介绍

    关于"引用"的几点说明介绍

    引用声明完毕后,相当于目标变量名有两个名称,即该目标原名称和引用名,且不能再把该引用名作为其他变量名的别名
    2013-09-09
  • 深入了解C++11中promise和future的使用

    深入了解C++11中promise和future的使用

    C++11中promise和future机制是用于并发编程的一种解决方案,用于在不同线程完成数据传递(异步操作)。Promise和Future提供了访问异步操作结果的机制,可以在线程之间传递数据和异常消息。本文就来聊聊二者的使用,希望对大家有所帮助
    2022-11-11
  • Visual Studio 2022 安装低版本 .Net Framework的图文教程

    Visual Studio 2022 安装低版本 .Net Framework的图文教程

    这篇文章主要介绍了Visual Studio 2022 如何安装低版本的 .Net Framework,首先打开 Visual Studio Installer 可以看到vs2022 只支持安装4.6及以上的版本,那么该如何安装4.6以下的版本,下面将详细介绍,需要的朋友可以参考下
    2022-09-09
  • C语言如何计算一个整数的位数

    C语言如何计算一个整数的位数

    这篇文章主要介绍了C语言如何计算一个整数的位数,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • Qt与Web混合开发实现双向通信的示例

    Qt与Web混合开发实现双向通信的示例

    本文主要介绍了Qt与Web混合开发实现双向通信的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-07-07
  • C语言中 type *(0)的具体使用

    C语言中 type *(0)的具体使用

    表达式 type * (0) 在 C/C++ 编程中是一个常见的技巧,通常用于内核编程和一些系统编程场景中,本文主要介绍了C语言中 type *(0)的具体使用,感兴趣的可以了解一下
    2024-08-08
  • C语言基础之格式化输出控制长度

    C语言基础之格式化输出控制长度

    这篇文章主要介绍了C语言基础之格式化输出控制长度的相关资料,需要的朋友可以参考下
    2017-04-04

最新评论