解题思路:完全是位运算,如果懂得位运算,非常简单,我写的方法是一种比较简单的方法了。
注意事项:
参考代码:
#include <stdio.h> int main() { unsigned int a,b; int i,n; scanf("%u%d",&a,&n); for(i=1;i<=n;i++) { b=a & 1;//取最后一位 a=a>>1; //右移,舍掉最后一位 if(b==1) //如果最后一位为1 a=a | 0x80000000;//则把a的最前面一位变成1,从而实现循环移位 } printf("%u\n",a); return 0; }
0.0分
12 人评分
C语言程序设计教程(第三版)课后习题7.3 (C语言代码)浏览:1276 |
C二级辅导-等差数列 (C语言代码)浏览:1315 |
C语言程序设计教程(第三版)课后习题9.8 (Java代码)浏览:1674 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:400 |
C语言程序设计教程(第三版)课后习题7.5 (C语言代码)浏览:901 |
C语言考试练习题_一元二次方程 (C语言代码)浏览:606 |
愚蠢的摄影师 (C++代码)浏览:980 |
C语言程序设计教程(第三版)课后习题10.3 (C语言代码)浏览:523 |
C二级辅导-同因查找 (C语言代码)浏览:618 |
模拟计算器 (C语言代码)浏览:2366 |
菜农 2019-11-06 14:00:08 |
a&1 ,也就是(举例子,不是具体数据)111001100111 & 000000000001,数电里边的与门
怪盗KID 2024-08-16 11:40:31 |
32位的数据a,右位移操作如果超限那么1将会移动到开头位置,32位1*10^32用16进制表示为8 0 0 0 0 0 0 0,所以这个时候按位或有相加的效果。