解题思路:
求16位负数的补码,首先将二进制字符串去掉符号位存入16位整数;然后异或32767,除了符号位,逐位取反;末位加一求得补码;再将16位整数转换成二进制补码存回字符串;对样例输入进行处理,如图所示:
注意事项:
用来接受输入的字符串数组:加上'\0'至少需要17个单元;计算负数的补码,正数保持原码。
参考代码:
#include<stdio.h> int main(){ char *buma(char *); char x[17]; scanf("%s",&x); printf("%s\n",buma(x)); return 0; } char *buma(char *s){ int i; short m,a; if(s[0]=='0') return s;//正数的补码是其本身 for(m=1,a=+0,i=15;i>0;i--){ a+=m*(s[i]-'0'); m*=2; }//将二进制字符串去掉符号位存入16位整数a a^=32767;//除了符号位,逐位取反 a++;//末位加一 for(i=15;i>0;i--){ s[i]='0'+a%2; a/=2; }//将16位整数a转换成二进制补码存回字符串 return s; }
0.0分
17 人评分
C语言程序设计教程(第三版)课后习题8.1 (C语言代码)浏览:774 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:668 |
不知道哪里错了浏览:1226 |
printf基础练习2 (C语言代码)浏览:605 |
P1002 (C语言代码)浏览:1019 |
【计算两点间的距离】 (C语言代码)浏览:927 |
C语言程序设计教程(第三版)课后习题1.5 (C++代码)浏览:1114 |
WU-蓝桥杯算法提高VIP-交换Easy (C++代码)浏览:1186 |
C语言程序设计教程(第三版)课后习题11.8 (C语言代码)浏览:910 |
WU-蓝桥杯算法提高VIP-勾股数 (C++代码)浏览:1685 |