整数A和B的二进制表示中有多少位不同

问题:给定两个正整数(二进制形式表示)A和B,问把A变为B需要改变多少位(bit)?也就是说,整数A和B的二进制表示中有多少位是不同的?
思路:对于给定的两个数,从最低位开始扫描,分别找到A和B的第一个“1”出现的位置,n1和n2
         1)n1==n2,将n1(n2)位置0,继续往高位找
         2)n1<n2, 说明A的n1位为1,但B的n1位为0,num++;将A的n1位置0,继续寻找A的下一个1的位置
         3)n1>n2, 同2)反之
程序:
int count(int a, int b)
{
    unsigned int n1,n2,num=0;
    n1=a-(a&(a-1));
    n2=b-(b&(b-1));
     while((n1!=0)&&(n2!=0))
    {
        if(n1==n2)
        {
            a&=~n1;
            b&=~n2;
            n1=a-(a&(a-1));
            n2=b-(b&(b-1));
        }
        else
        {
            num++;
            if(n1<n2)
            {a&=(~n1);n1=a-(a&(a-1));
            }
            else
            {b&=(~n2);n2=b-(b&(b-1));
            }
        }
    }
    while(n1!=0)
    {
     num++;a&=(~n1);n1=a-(a&(a-1));
    }
    while(n2!=0)
    {num++;b&=(~n2);n2=b-(b&(b-1));
    }
    return num;
}
复杂性分析:始终在追踪“1”,因此复杂性为O(V(A|B)),V(A|B)为A|B中的“1”的个数,
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 MATLAB 中,可以使用 bin2dec 函数将一个二进制数转换为十进制数。但是,如果这个二进制数是一个有符号整数的补码表示,那么需要进行一些额外的操作才能将其转换为有符号整数。 假设你的十六二进制数是一个有符号整数的补码表示,那么可以按照以下步骤将其转换为有符号整数: 1. 将十六二进制数转换为 MATLAB 中的整数类型。 2. 判断这个整数的最高位是否为 1,如果为 1,则说明这个二进制数代表的是一个负数。 3. 如果这个二进制数代表的是一个负数,则需要进行如下操作: a. 将这个整数减去 2^15,得到它的反码表示。 b. 将反码表示取反,得到它的补码表示。 4. 如果这个二进制数代表的是一个正数,则直接使用 bin2dec 函数将其转换为十进制数。 以下是一个示例代码: ``` % 假设你的十六二进制数是 '1101111101101000' binStr = '1101111101101000'; % 将二进制数转换为 MATLAB 中的整数类型 num = bin2dec(binStr); % 判断最高位是否为 1 if binStr(1) == '1' % 如果是负数,则进行如下操作 num = num - 2^15; % 得到反码表示 num = bitcmp(num, 16); % 得到补码表示 end % 输结果 disp(num); ``` 这个代码的输结果应该是一个有符号整数,可以正常进行计算。注意,在这个示例代码中,假设你的十六二进制数是一个有符号整数的补码表示,如果是其他的二进制表示,可能需要进行不同的转换操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值