解题思路:左(右)移时判断最高(低)位的值,为1则移位后在最低(高)位写入1,否则只移位
注意事项:
参考代码:
#include <stdio.h> unsigned int move(unsigned int value,int n) { if(n<0) { while(n++) { if(value&0x80000000)//最高位为1 { value*=2;//左移1位 value|=0x00000001;//按位或将末位写入1 } else { value*=2;//否则只左移 } } } else if(n>0) { while(n--) { if(value&0x00000001)//末位为1 { value/=2;//右移1位 value|=0x10000000;//按位或最高位写入1 } else { value/=2;//否则只右移 } } } return value; } int main() { unsigned int val; int n; scanf("%u %d",&val,&n); val=move(val,n); printf("%u\n",val); return 0; }
0.0分
0 人评分