ACM_Reverse Bits(反转二进制)
Reverse Bits
Time Limit: 2000/1000ms (Java/Others)
Problem Description:
Reverse bits of a given 32 bits signed integer.For example, given input 43261596 (represented in binary as 00000010100101000001111010011100), return 964176192 (represented in binary as 00111001011110000010100101000000).
Input:
The input includes several cases. For each case,input a 32-bits signed integer.
Output:
For each case,output the answer.
Sample Input:
43261596
Sample Output:
964176192
解题思路:简单地将二进制转化成十进制。如果n是负数,先将其转化成正数,取反后再加1,但是有一种特殊情况需要特判,即n==-2147483648(1<<31)由于取n的绝对值之后会溢出int最大值2147483647,因此需要单独判断这种情况,其二进制反转之后的结果为1。
AC代码一之简单模拟:
1 #include<bits/stdc++.h> 2 using namespace std; 3 int main(){ 4 int n,m,k,tmp,base,d[32]; 5 while(cin>>n){ 6 if(n==(1<<31)){cout<<1<<endl;continue;}//特判:n==-2147483648反转32位二进制后结果为1 7 memset(d,0,sizeof(d));k=0;tmp=base=1;m=n; 8 if(m<0)m=-n; 9 while(m){d[k++]=m%2;m/=2;}//取余操作 10 if(n<0){//如果n小于0,将n取反再加1 11 for(int i=0;i<32;++i){ 12 d[i]=((d[i]==1?0:1)+tmp)%2;//按位取反,tmp初始值为1 13 tmp=((d[i]==1?0:1)+tmp)/2; 14 } 15 } 16 for(int i=31;i>=0;--i){ 17 if(d[i])m+=base;//从高位向低位计算,相当于反转32位二进制之后从低位向高位计算 18 base*=2; 19 } 20 cout<<m<<endl; 21 } 22 return 0; 23 }
AC代码二之'且'运算符的巧妙使用:从第0位到第31位,有1就取。
1 #include<bits/stdc++.h> 2 using namespace std; 3 int main(){ 4 int n,m; 5 while(cin>>n){m=0; 6 for(int i=0;i<32;++i) 7 if(n&(1<<i))m+=(1<<(31-i));//如果二进制的第i位上为1,则加上2^(31-i) 8 cout<<m<<endl; 9 } 10 return 0; 11 }
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET 9 new features-C#13新的锁类型和语义
· Linux系统下SQL Server数据库镜像配置全流程详解
· 现代计算机视觉入门之:什么是视频
· 你所不知道的 C/C++ 宏知识
· 聊一聊 操作系统蓝屏 c0000102 的故障分析
· DeepSeek V3 两周使用总结
· 回顾我的软件开发经历(1)
· C#使用yield关键字提升迭代性能与效率
· 低成本高可用方案!Linux系统下SQL Server数据库镜像配置全流程详解
· 4. 使用sql查询excel内容