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

C语言负数做运算你会了吗

\n", a%c); printf("结果4: %d\n", a/d); printf("结果5: %d\n", b/c); printf("结果6: %d\n", a/c);...发现在输入负数时结果会出问题,这么一来大概就知道问题出在什么地方了。 先来看一下上面示例代码的输出的结果,有没有和你想的一样?...C语言中的负数取余取整规则 我们先来考虑一下,为什么上面示例代码的在取余和取整时符号不同呢,这就涉及到C语言负数参与除法时符号的问题。...C 语言负数做除法的时候,商是令其与分母相乘的积的绝对值不超过分子的绝对值且最接近的那个数。...取余时,余数与被除数(即分子的符号)相同 取整时,先将各个带符号的数全部取正值再做除法,再根据负号的个数确定商的符号 总结 这个问题在C语言中看似简单,但是往往不注意也可能会引起大问题。

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

    C语言笔记】参函数

    提到参函数,我们的感觉是不是既熟悉又陌生?感觉熟悉是因为我们平时都在使用着,如我们常使用的printf()函数与scanf()函数就是典型的参函数。...因为printf()函数是参函数我们才可以根据我们的需要灵活地输出变量的值。...//给printf函数传入n个参数 我们可以根据需要给printf()函数传入n个参数,这就是参函数。 感觉陌生是因为我们没有试着创建参函数。...要创建参函数需要包含头文件stdarg.h,并且创建参函数应按照如下步骤进行: 【第一步】定义一个使用省略号的函数原型,如printf()与scanf()函数的原型为 int printf (const...2.0, 3.0, 4.0, 5.0, 6.0); printf("sum1 = %f\n", sum1); printf("sum2 = %f\n", sum2); return 0; } 参函数

    1.1K40

    如何到达C语言的巅峰?我推荐你阅读《C语言小白怪兽》!

    ---- 8年的编程功力 + 5年的精雕细琢 + 5次大改版 + 文学级的写作能力 ---- 各位学习C语言的小伙伴,今天给大家推荐一部经典的C语言教程——C语言小白怪兽。...《C语言小白怪兽》融入了作者 8 年的编程功力,以及文学级的写作能力,耗时 5 年完成,期间经过了 5 次大改版。 作者的执着和专注让我非常感动。在这个浮躁的年代,能沉下心了写一部教程着实不易。...《C语言小白怪兽》除了讲解语法知识,还重点讲解了: 1) 学习规划 告诉读者如何学习C语言,如何避免踩坑,分析程序员的发展方向以及高薪秘诀。 2) 内存 内存是菜鸟和大神的分水岭!...《C语言小白怪兽》处处涉及内存,从内存的角度分析每一个知识点,让读者看透本质。 此外还有一个《C语言和内存》专题,从更加宏观的层面讲解程序在内存中的分布,以及计算机控制内存的秘密。 ?...3) 字符编码 本教程还会揭开C语言界的一个弥天大谎:很多老师和教材都说C语言使用 ASCII 编码,这其实是彻头彻尾的错误,而且错得非常荒谬。

    7.8K86

    c语言void什么作用,C语言中void是什么意思?

    C语言中void是什么意思?...C语言中“void”表示为无类型,相应的“void *”为无类型指针,常用在程序编写中对定义函数的参数类型、返回值、函数中指针类型进行声明,其作用是对函数返回和参数的进行限定。...C语言关键字 auto :声明自动变量 break:跳出当前循环 case:开关语句分支 char :声明字符型变量或函数返回值类型 const :声明只读变量 continue:结束当前循环,开始下一轮循环...声明无符号类型变量或函数 union:声明共用体类型 void :声明函数无返回值或无参数,声明无类型指针 volatile:说明变量在程序执行中可被隐含地改变 while :循环语句的循环条件 推荐教程:《C#...while :循环语句的循环条件 推荐教程:《C#》 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/144444.html原文链接:https://javaforall.c

    3.4K20

    C语言入门:输入任意一个正数(奇数),判断是否为质数

    C语言永远不会过时 其实学编程关键是学习其思想,如果你精通了一门,再去学其他的时候也很容易上手。C不会过时的,尤其是在unix、linux操作平台上,学好C是必须的。...CC++在很多方面也是兼容的,cc++的基础。 再者c能从很大的程度上帮你了解计算机的发展史,数据结构等方面的知识,很多软件、甚至操作系统中的很大部分是用c来实现的。...还有一些电器芯片的程序,比如电冰箱内制冷系统……可以说用c可以解决一切可能遇到的问题,关键是你要能精通它。...所以放开手脚去大胆的学吧,c永远不会过时 小编给大家推荐一个学习氛围超好的地方,C/C++交流企鹅裙:870963251!适合在校大学生,小白,想转行,想通过这个找工作的加入。...裙有大量学习资料,有大神解答交流问题,每晚都有免费的直播课程 源代码: #include void main() { int a,b; while(1) { printf("请输入任意正整数(奇数)

    1.3K20

    c语言存储类的关键字(一)

    前言 今天我们暂时不分享Linux网络编程的文章(明天来分享Linux网络编程的实战文章),今天接着分享c专题系列文章存储类的关键字的使用方法和总结: -auto- (1)auto关键字在C语言中只有一个作用...- static - (1)static关键字在C语言中有2种用法,而且这两种用法彼此没有任何关联、完全是独立的。...其实当年本应该多发明一个关键字,但是C语言的作者觉得关键字太多不好,于是给static增加了一种用法,导致static一个关键字竟然有两种截然不同的含义。...(2)内链接的意思就是(c文件内部)内部链接属性,也就是说这家伙可以在当前c文件内部范围内进行链接(言下之意就是不能在当前c文件外面的其他c文件中进行访问、链接)。...关键字修饰),想必搞stm32的读者,都有接触到(这里的话,我就不例子了);当你的程序中有很多源文件的时候(这在写stm32的时候经常遇到,而且经常要养成多文件不被重复包含的写法代码习惯),一般在stm32面会使用这个

    48750

    计算机基础之位运算 | 按位取反

    原码: 正数是其二进制本身; 负数是符号位为1,数值部分取X绝对值的二进制。 反码: 正数的反码和原码相同; 负数是符号位为1,其它位是原码取反。...补码: 正数的补码和原码,反码相同; 负数是符号位为1,其它位是原码取反,未位加1。...(反码末尾减1)(或者说负数的补码是其绝对值反码未位加1) 取反就是简单的 01,10 ; 而按位取反需要涉及以上概念。...(正数补码同反码) - 补取反 : 1111 0110 (全位01,10) - 算反码 : 1111 0101 (末位减1) - 算原码 : 1111 1010 (其他位取反) 总结规律: ~x...关于位运算看这个就够了 C语言位操作中指定的某一位数置0、置1、取反 负数的二进制表示 原码, 反码, 补码 详解 C/C++ 数据范围int 取反!

    6.6K10

    按位取反的概念和计算方法「建议收藏」

    取反:01,10 反码:正数的反码是其本身,对于负数其符号位不变其它各位取反(01,10) 按位取反(~): 这将是下面要讨论的。...“~”运算符在cc++、java、c#中都有,之前一直没有遇到这个运算符。 要弄懂这个运算符的计算方法,首先必须明白二进制数在内存中的存放形式,二进制数在内存中是以补码的形式存放的。...另外正数负数的补码不一样,正数的补码、反码都是其本身,既: 正数9: 原码为: 0000 1001 补码为: 0000 1001 反码为: 0000 1001 再例如: -2 求原码: 1111 0010...取反过程符号位是不变的哦) 前面4个1是符号位,1是负数,既得十进制:-10 不知道说的明不明白,这里步骤就是: 1. 先对正数求补码 2. 然后对补码取反,包括符号位 3....零的按位取反是 -1(0在数学界既不是正数也不是负数) [cpp] view plain copy // 测试-1亿 到 1亿的所有整数 :) for (int i = 0; i <= 100000000

    4.4K30

    Verilog 中负数的 % 取余数运算、C语言、Matlab各自的取余数运算【%】【mod】【rem】

    . -2 C. 1 D. -1 答案:D 解析: Verilog 的 %,求余数: 10 % 3 = 1 -10 %3 = -1 10 % (-3) = 1 -10 %(-3) = -1 Verilog...的模运算,先把各自符号位去掉运算,然后取第一个运算数的符号位,即都直接算 10 % 3 = 1,然后如果前面是 10 模式就是 1,前面是 -10 模值就是 -1; 余数符号跟随被除数的符号位。...C语言的 %,求余数: 和 Verilog 一样,余数符号跟随被除数的符号位。 先去掉符号取余数,被除数是正数,则余数为正数;被除数为负数,则余数为负数。 ?...该结果与 Verilog 和 C 语言的 % 结果一致: 余数符号跟随被除数的符号位。 这里特别注意 Matlab 中的 mod 取模运算,以前经常把 % 叫做取模,计算方式不一样。...,就是数值越小越好,当商为负数,就往取绝对值后比较大的方向取,即都向着负无穷方向取。

    11.3K31

    按位取反怎么运算_按位取反运算

    取反:01,10 反码:正数的反码是其本身,对于负数其符号位不变其它各位取反(01,10) 按位取反(~): 这将是下面要讨论的。...————————————————————————————————- “~”运算符在cc++、java、c#中都有,之前一直没有遇到这个运算符。...另外正数负数的补码不一样,正数的补码、反码都是其本身,既: 正数9: 取原码: 0000 1001 取补码: 0000 1001 取反码: 0000 1001 内存中存放格式 0000 1001 再例如...所有正整数的按位取反是其本身+1的负数 2. 所有负整数的按位取反是其本身+1的绝对值 3....零的按位取反是 -1(0在数学界既不是正数也不是负数) // 测试-1亿 到 1亿的所有整数 :) for (int i = 0; i <= 100000000;++i) { if (~i

    2K20

    正数负数和补码_正数原码反码补码

    计算机中,正数负数是怎么区分的呢,如何存放正数负数?...负数的反码除最高位符号位外,其他位都取反; 3、补码:在反码的基础上加1,这样可以方便计算机进行计算,可以让**最高位符号位都能参与计算**; 正数的补码就是原码本身,负数的补码是其反码加1,我们以C...以C语言的有符号数为例: int a = 0x80000000; int型总共占4字节,因此内存中的a变量应该是下面这样子: 1000 0000 0000 0000 0000 0000 0000 0000...了解了正、负数在计算机内存中的存放方式以及整数反转,那么如何在不改变数据类型的前提下正确存放一个十进制大正数到内存呢?...这个场景其实会存在于进程间数据交互的情况,比如我用一个python脚本发送了一个大正数C语言开发的一个接口,然后这个数字超过了int能表示的最大的正数,但实际上二进制长度并没有超过int的内存大小。

    1.7K50
    领券