整数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”的个数,
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值