以字符数组的方式处理的,感觉有点非主流。。
参考代码如下:
#include <stdio.h> //原码转化为补码,分两种情况:1.正数不变2.负数原码符号位不变,其余位取反加一 int main(void) { char bits[16]; int i; for (i = 0; i < 16; i++) { bits[i] = getc(stdin); if (bits[0] == '0') //正数,不用处理 { continue; } if (bits[0] == '1') //负数,其余位取反 { if (i > 0) { if (bits[i] == '1') bits[i] = '0'; else if (bits[i] == '0') bits[i] = '1'; } } } if (bits[0] == '1') //负数,最后一位加1 { //从后往前遍历 for (i = 15; i >= 0; i--) { if (bits[i] == '0') //碰到'0'时置为'1',就可以退出了 { bits[i] = '1'; break; } if (bits[i] == '1') { bits[i] = '0'; } } } //输出补码 for (i = 0; i < 16; i++) { putchar(bits[i]); } printf("\n"); return 0; }
0.0分
8 人评分
C语言程序设计教程(第三版)课后习题9.6 (C语言代码)浏览:597 |
1051(奇了怪了)浏览:747 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:729 |
简单的a+b (C语言代码)浏览:857 |
小O的数字 (C语言代码)浏览:1490 |
10月月赛题解浏览:554 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:620 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:526 |
C语言程序设计教程(第三版)课后习题5.8 (C语言代码)浏览:672 |
ACM俱乐部密码浏览:948 |