问题 B: 二进制转换
题目描述
LZY自从加入到了出题组中,整天想着他以前的那块二进制手表。营长为了让他多熟悉熟悉二进制,准备考考他。现在给LZY两个整数N和M,请问要将N的二进制改变几个位才能变成M?LZY比较笨,现在他来求助你们了。你们能帮帮他嘛?
输入
测试样例由多组测试数据组成。每组测试数据第一行输入两个整数 N 和 M ( -2147483648 <= N,M <= 2147483647 )
输出
输出要改变几位的二进制才能使N变成M
样例输入
1 2
29 15
样例输出
2
2
AC代码:
#include<bits/stdc++.h>
using namespace std;
int main(){
int a,b;
while(cin>>a>>b){
int c=a^b;
int ans=0;
for(int i=1;i<=32;i++){
if(c&1==1) ans++;
c>>=1;
}
cout<<ans<<endl;
}
return 0;
}
这里限制太多,打不出来;康康网址吧
掰掰