重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
int negate(int x)
成都创新互联从2013年开始,是专业互联网技术服务公司,拥有项目网站制作、做网站网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元壶关做网站,已为上家服务,为壶关各地企业和个人服务,联系电话:18982081108
{
return (0-x);
}
int my_abs(int)
{
return (x0)?x:(0-x);
}
直接拿0减去就行,
比如:
int n=-5;
0-5 就得到了+5
这是常用的正负转换
确实跟补码有关
计算机为了使减法变为加法把负数用补码来存储(正数也是只不过正数的补码与原码相同)
以钟表为例
例如: 假设当前时针指向10点,而准确时间是6点,调整时间可有以下两种拨法:
一种是倒拨4小时,即:10-4=6
另一种是顺拨8小时:10+8=12+6=6
计算机内部计算类似于上面 它把(-4)变成储存为12-4=8(即所谓的补码)
而计算机计算10-4时它就变成10+8=18 而钟表最大值为12所以18-12=6 于是计算就完成了
(1)正数的补码:与原码相同(因为它本身是加数计算机可以计算所以不用变)。
例如,+9的补码是00001001。
(2)负数的补码:符号位为1,其余位为该数绝对值的原码按位取反;然后整个数加1。(因为它不是是加数计算机不可以计算 所以要变成补码)
例如,-7的补码:因为是负数,则符号位为“1”,整个为10000111;其余7位为-7的绝对值+7的原码
0000111按位取反为1111000;再加1,所以-7的补码是11111001。简单点就是10000000( 128)-0000111(7)=11111001(121)
而C语言中有符号的整数为16位从00000000,00000000 到011111111,11111111 即0到32767为正数所以补码为原码
从11111111,11111111 到10000000,00000000
为-1到-32768