左嘉


私信TA

用户名:zuojia

访问量:82633

签 名:

Jz

等  级
排  名 4
经  验 33590
参赛次数 226
文章发表 72
年  龄 40
在职情况 在职
学  校 北京理工大学
专  业

  自我简介:

解题思路:
求16位负数的补码,首先将二进制字符串去掉符号位存入16位整数;然后异或32767,除了符号位,逐位取反;末位加一求得补码;再将16位整数转换成二进制补码存回字符串;对样例输入进行处理,如图所示:1776.png

注意事项:
用来接受输入的字符串数组:加上'\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分

11 人评分

  评论区

6666666
2024-04-03 16:13:07
#include<iostream>
using namespace std;
int main()
{
    char s[16];
    int i;
    cin>>s;
    for(i=1;i<15;i++)
    {
        if(s[i]=='0')
        s[i]='1';
        else
        s[i]='0';
    }
    cout<<s<<endl;
    return 0;
}
2023-06-08 12:52:38
巨佬
2021-04-04 09:31:55
666
2020-12-07 00:01:09
  • «
  • 1
  • »