解题思路:完全是位运算,如果懂得位运算,非常简单,我写的方法是一种比较简单的方法了。
注意事项:
参考代码:
#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分
10 人评分
不容易系列 (C语言代码)浏览:665 |
【绝对值排序】 (C语言代码)浏览:820 |
The 3n + 1 problem (C语言代码)浏览:548 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:780 |
判定字符位置 (C语言代码)浏览:792 |
找出最长的字符串来 (C语言代码)浏览:1762 |
C语言程序设计教程(第三版)课后习题7.2 (C语言代码)浏览:740 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:581 |
C语言程序设计教程(第三版)课后习题9.10 (C语言代码)浏览:614 |
A+B for Input-Output Practice (II) (C语言代码)浏览:597 |
菜农 2019-11-06 14:00:08 |
a&1 ,也就是(举例子,不是具体数据)111001100111 & 000000000001,数电里边的与门