第一位符号位1为负,0为正。 正数的补码和2进制原码是一样的。
负数的补码:
1、先取绝对值|x| ;
2、对|X|+1 ;
3、对|X|+1 取反,就得到它的补码了 。
计算机中存放整型数据都是按补码的形式存放的。
扩展资料:
有符号数的表示方法是由硬件决定,而不是由C决败好型定的。有三种表示方法:
1、二进制原码
0000 0001 表示 1
1000 0001 表示 -1
这个方法有个缺点是有两个零: +0 和 -0。这会引起混淆,而且用两个位组合来表示一个值也有些浪费。
2、二进制补码(最普遍的系统)
区别在于 singned 和 unsigned:
1)如果是无符号字节, 1000 0000 该组合为 128
2)如果是有符号字节, 1000 0000 该组合为 -128
第一种表袜隐示数的范围是 0 ~ 255;
第二种表示数的范围是 -128 ~ +127,对于一个二进制补码数取负数,最简单的方法就是取反、加 1。察猜
3、二进制反码
通过反转位组合中的每一位以形成一个数的负数,例如:
0000 0001 表示 1
1111 1110 表示 -1
这种方式也有一个 -0:1111 1111。其范围是 -127 ~ +127。
1.负数在现代计算机里一般用补码表示,为什么呢?原因是:保证0的左右不矛盾
1是0001,推算出0是0000;基春
-1的是1111,搏睁耐推算出0也是0000。
如果直接用反码(0变成1,1变成0)那么0就会有两个结果。
如果用第一位表示符号,后三位表示大小,那么就有空间浪费。
2.char类型是8位,1000 0000还原为原码:
最高位是早老1,表示负数,剩余的各位取反 111 1111 再+1 得到 1000 0000, +128的原码,整个数为-128
求采纳为满意回答。
#include
#include
int main(void)
{
腊旁double a, b, c;
scanf("%lf %lf %lf", &a, &b, &c);
清配double delta = b * b - 4.0 * a * c;
double x1 轮正橡= (-b - sqrt(delta)) / (2.0 * a);
double x2 = (-b + sqrt(delta)) / (2.0 * a);
printf("%.2f %.2f\n", x1, x2);
return 0;
}
-b 直接写成这样就是了。
直接在变量b前轮闹面加-(负号)即兆袜可。
设b=5
那么int a=-b 此时a=-5
再比如
设b=-5
int a=-b 此a=5 因为它相当于族桐激int a=-(-5) 即负负得正。
就直含培丛接写啊,
举个例子啊:谈樱
int a = 19;
int b = 0-a; 这里b就是负数中帆了,0-19就是 -19了。