首页  >  文章  >  后端开发  >  使用C语言找到给定二进制数的2的补码

使用C语言找到给定二进制数的2的补码

PHPz
PHPz转载
2023-09-05 15:21:061174浏览

使用C语言找到给定二进制数的2的补码

考虑下面给出的示例 -

示例

输入如下:

输入二进制数:10010001

输出如下:

1 对 10010001 的补码是 01101110

2 对 10010001 的补码是 01101111

算法

参考一种算法来查找给定二进制数的 2'c 补数。

第 1 步 - 开始。

第 2 步 - 阅读运行时的二进制数。

第 3 步 - 将二进制数复制到 strdp。

第 4 步 - len: = strlen(str)

第 5 步 - 对于i = 0 到 len-1 执行

     步骤 5.1 - 如果 str[i] == '1' 则

        步骤 5.1.1 - str[i] == '0'

     步骤 5.2 - 否则

        步骤 5.2.1 - str[i] == '1'

     步骤 5.3 - i: = i+1

     步骤 5.3 - i: = i+1

p>

第 6 步 - 掩码:= 1

第 7 步 - 对于 i: = len-1 到 0 执行

     步骤 7.1 - 如果掩码 == 1 则 p>

        步骤 7.1.1 − 如果 str[i] == '1' 则

           步骤 7.1.1.1 − str[i]: = '0'

           步骤7.1.1.2 − mask: = 1

     步骤 7.1.2 − else

        步骤 7.1.2.1 − str[i]: = '1'

        步骤7.1.2.2 - 掩码:= 0

     步骤 7.1.3 - 结束 if

     步骤 7.2 - 结束 if

步骤 8 - 打印 2 的补码。

第 9 步 - 停止。

程序

以下是 C 程序,用于查找给定二进制数的 2'c 补码 -

 现场演示

#include <string.h>
#include<stdio.h>
main(){
   char str[32],strdp[32];
   int mask,i;
   printf("Enter a binary number:");
   scanf("%s",str);
   strcpy(strdp,str);
   for(i=0;i<strlen(str);i++) /* computing 1&#39;s complement */{
      if(str[i]==&#39;1&#39;)
         str[i]=&#39;0&#39;;
      else
         str[i]=&#39;1&#39;;
   }
   printf("1\&#39;s complement of %s is %s</p><p>",strdp,str);
   mask=1;
   for(i=strlen(str)-1;i>=0;i--){
      if(mask==1){
         if(str[i]==&#39;1&#39;){
            str[i]=&#39;0&#39;;
            mask=1;
         }
         else{
            str[i]=&#39;1&#39;;
            mask=0;
         }
      }
   }
   printf("2\&#39;s complement of %s is %s",strdp,str);
}

输出

当执行上述程序时,会产生以下结果 -

Enter a binary number:11001110
1&#39;s complement of 11001110 is 00110001
2&#39;s complement of 11001110 is 00110010

以上是使用C语言找到给定二进制数的2的补码的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文转载于:tutorialspoint.com。如有侵权,请联系admin@php.cn删除