以字符数组的方式处理的,感觉有点非主流。。
参考代码如下:
#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语言程序设计教程(第三版)课后习题8.1 (C语言代码)浏览:438 |
C语言程序设计教程(第三版)课后习题6.10 (C语言代码)浏览:552 |
【蟠桃记】 (C语言代码)浏览:664 |
WU-字符串比较 (C++代码)浏览:754 |
DNA (C语言描述,数据结构)浏览:851 |
【计算球体积】 (C语言代码)浏览:1101 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:504 |
1048题解(读入回车问题)浏览:554 |
简单的a+b (C语言代码)浏览:945 |
简单的a+b (C语言代码)浏览:504 |