首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C语言符号-取余取模运算

,在C语言中本质是向0取整 当然对于向0取整我们也可以使用trunc库函数 (需包含math.h头文件) 示例: #include #include /...0; } 对于负数取模 示例: int main() { int a = -10; int d = 3; printf("%d\n", a/d); //C语言中是-3,...python是-4 printf("%d\n", a%d);//C语言中是-1,python是2 return 0; } 为什么就有差异了呢?...,向-∞方向取整 从而C中%,本质其实是取余;Python中%,本质其实是取模 对任何一个大于0的数,对其进行0向取整和-∞取整,取整方向是一致的,故取模等价于取余 对任何一个小于0的数...,对其进行0向取整和-∞取整,取整方向是相反的,故取模不等价于取余 结论: 两个同符号数据参与取余,取模等价于取余,不同语言余数相等 两个不符号数据参与取余,取模不等价于取余,余数大小需考虑语言取整规则

3.2K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Java取余和取模

    抛开高级语言的实现,取余运算和取模运算本身并不完全一致,区别在于对负整数进行取商时操作不同。虽然这样说,但是取余运算和取模运算的公式都一样。...先给出规则,如果z小于0,且z不为整数(即x没有被y整除),那么: 如果是取余:那么z朝0方向取整,即:-1.33 => -1 如果是取模:那么z朝负无穷方向取整,即:-1.33 => -2 举个例子:...– 3 * (-2) == 2 所以大家不要再把取余和取模混为一谈啦!...在Java中,%是取余数,取模的操作是:Math.floorMod,我们可以看一下Java的取模操作是怎么实现的(以下为java源码,只是我加上了注释): /** *计算 x - z */ public...r--; } return r; } 注:不同的语言,对于%运算符的含义可能是不一样的,比如c、c++、java 为取余,而python为取模 发布者

    2.2K10

    【C语言简单说】六:取模运算符以及变量的扩展

    ┴┴ (╰(`□′)╯( ┴┴ … 这一节我们就来说另外的运算符——取模运算符(说白了跟取余数差不多…<—_-)!!!) 先看看好难懂的定义:取模运算和取余运算两个概念有重叠的部分但又不完全一致。...…(后面太罗嗦就不复制了) 取模也是一种运算,叫做取模运算…(貌似有点废话<—_-)!!!)...c=b%a; printf("b取模a 的值是%d;\n",c); system("pause"); } 我们看c=b%a 就是取模运算,把运算结果给...c变量,从而再输出出来。...取模运算其实就是,我们姑且就当作取余数。我们看代码我们的b是5,a是1,那么取模的运算结果等于1,那是因为5除2余1…好了就是那么简单。反正我数学不好=。

    1K10

    Java与C语言中取模运算符%的区别对比

    不同的编程语言对取模运算符的实现和使用会有所不同,今天我们将通过对比Java和C语言中的 % 运算符,详细了解它们在使用上的差异。...我们还会深入分析这两种语言在实现和结果上的差异,帮助读者更好地理解它们。 Java C语言中的取模运算符 % 基本行为 在C语言中,取模运算符 % 的主要功能是计算两个整数相除后的余数。...浮点数支持 C语言:不支持浮点数取模。% 运算符只适用于整数类型。 Java:支持浮点数取模。对于浮点数,Java计算的是浮点数余数,而不仅仅是整数余数。...除法和取模的关系 取模运算与除法密切相关。对于整数来说,除法和取模运算是成对出现的,且除法结果和取模结果可以一起用于构建更复杂的数学运算。 C语言与Java:在这两种语言中,除法和取模的行为基本一致。...C语言的取模运算符只能用于整数类型,并且不支持浮点数取模。而Java的取模运算符则更为灵活,不仅支持整数类型,还支持浮点数类型。

    6010

    java 取余 小数_Java小数取余问题求助「建议收藏」

    严重BS楼上的,尤其是说java语言的那位。 我来告诉你 这个问题用递推解决 首先要你承认一个公式,我是习惯pascal语言的,c++怕写错,反正只是算法,你忍一下。...不知道你要的算法是大整数对long取余还是大整数对大整数取余。...先说对long取余,这个简单 先承认两个公式:ab mod c=((a mod c)(b mod c)) mod c (a+b) mod c=(a mod c+b mod c) mod c 然后递推,先算...1 mod c,然后10 mod c ,100 mod c。。。...再说大整数对大整数取余,这个需要模仿你平常做的除法来做高精度除法,说明白了就是模拟除法,这个没什么好说的,只要你编程能力足够就写得出来,你可以上网上搜一下,我这就不写了,因为我也不能保证一次写对,因为写一个高精度除法需要高精度加法和乘法

    1.4K20

    Utility之负数取模

    最近在跟孩子学习表内除法,想到一个问题:C语言里怎样处理负数取模? 表内除法:12÷4=3 整数除法:13÷4=3…1 整数整除:13/4是等于3吗? 负数取模:-13%4等于多少?...明明除不尽,又要求结果是整数,一般有这样几种方法: 向上取整(Ceiling),即向+∞靠齐,也就是取比浮点数结果稍大的最小整数。...向零取整(Truncate),即向0靠齐,也就是舍去小数部分。那么:13/4=3;-13/4=-3;15/4=3;-15/4=-3。...而C语言里的整除,采用的就是向零取整(Truncate)。 再来看取模。不管哪种整除操作,都会符合公式:被除数÷除数=商…余数,所以:余数=被除数-除数*商。...那么C语言里取模就是: 13÷4=3…1;-13÷4=-3…-1;13÷-4=-3…1;-13÷-4=3…-1 15÷4=3…3;-15÷4=-3…-3;15÷-4=-3…3;-15÷-4=3…-3

    1.5K20

    % 不是取模运算符?

    为什么我问这个问题,因为我今天才发现不同语言中 % 的含义是不同的,因为我是主学 java 的,一直以为 % 就是取模,但是我错了。...第一步:先求c = a / n,结果是 -2(向负无穷方向舍入) 和 -1(向0方向舍入); 第二步:计算模和余数的公式相同,但因 c 的值不同,求模时r = 3,求余时r = -7。...总结:当a和n符号一致时,求模运算和求余运算所得的c的值一致,因此结果一致。当符号不一致时,结果不一样。求模运算结果的符号和n一致,求余运算结果的符号和a一致。...各个环境下 % 运算符的含义不同,比如 C/OC/C++,Java 中为取余,而 Python 则为取模。 所以我们的疑惑就解开了,因为在 Python 中 % 是取模,而在 Java 中为求余。...因为不是 Python 规定的向负无穷取整,而是取模运算就是往负无穷取整,在 Python 中 % 是取模运算,而在那几个语言中是取余运算。 个人理解,如有疏漏请指出。

    1.7K20

    c语言自定义输出小数点位数_c语言double类型默认输出小数几位

    C语言中常用的小数有两种类型,分别是 float 或 double;float 称为单精度浮点型,double 称为双精度浮点型。...不像整数,小数没有那么多幺蛾子,小数的长度是固定的,float 始终占用4个字节,double 始终占用8个字节。 c语言double类型默认输出几位小数?...C语言中,输出double类型(双精度实型)以及float类型(单精度实型)时,默认输出6位小数(不足六位以 0 补齐,超过六位按四舍五入截断)。...比如计算平均分,一到两位小数就足够了。可是有时六位又不够,需要更多位小数,比如计算高精度平方根。这时可以用printf的格式控制。如果要输出n位小数,那么可以用%.nlf的格式。其中n为数字。...内容扩展 小数的输出 小数也可以使用 printf 函数输出,包括十进制形式和指数形式,它们对应的格式控制符分别是: %f 以十进制形式输出 float 类型; %lf 以十进制形式输出 double

    1.9K20

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券